【问题标题】:Use SELECT results as column name for parent SELECT使用 SELECT 结果作为父 SELECT 的列名
【发布时间】:2020-04-06 15:29:51
【问题描述】:

我有一个 TMP_FOO 表,它具有与 FOO 相同的列以及更多列。我需要将 TMP_FOO 中的所有行插入 FOO。我可以写如下:

INSERT INTO FOO (SELECT bar, baz FROM TMP_FOO);

但我需要它是通用的,以便我只更改表的名称。我最好的尝试:

INSERT INTO FOO
(SELECT 
  (SELECT column_name
  FROM USER_TAB_COLUMNS
  WHERE table_name = 'FOO')
FROM
 f2020.TMP_FOO)

这不起作用,因为

SELECT column_name
FROM USER_TAB_COLUMNS
WHERE table_name = 'FOO'

返回多行。我可以用纯 SQL 归档我想要的内容吗(无需动态构建查询字符串)?

【问题讨论】:

  • 不,你不能用静态 SQL 做到这一点。它必须是动态的——要么是实际的动态 SQL,要么是使用客户端变量(例如 SQL*Plus 替换变量)。 This might be relevant?

标签: sql oracle select sql-insert


【解决方案1】:

我可以用纯 SQL 归档我想要的内容吗(无需动态构建查询字符串)?

没有。

在纯 SQL 中,您无法从另一个查询生成输出列的列表。数据库在解析查询时需要知道查询将返回哪些列(即在查询实际执行之前)。

【讨论】:

    【解决方案2】:

    您不要使用结果中的列 names,INSERT INTO 表 SELECT 必须保持与目标表相同的列数。我认为,这是不可能创建列列表运行时的。您必须键入 FOO 的所有列 - 作为您的第一个示例:

    INSERT INTO FOO (SELECT FOO_colname_1, FOO_colname_2, FOO_colname_3 FROM TMP_FOO);
    

    反之,如果 FOO_TEMP 有更多列,则必须添加 NULL 或默认值:

    INSERT INTO TMP_FOO (SELECT TMP_FOO_colname_1, TMP_FOO_colname_2, TMP_FOO_colname_3, NULL, NULL FROM FOO);
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2012-07-15
      • 1970-01-01
      • 2023-02-03
      • 2014-02-11
      • 2020-10-15
      • 1970-01-01
      • 2017-04-28
      相关资源
      最近更新 更多