【发布时间】: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