我在这里读到,语法看起来是这样的:
INSERT
WHEN ([Condition]) THEN
INTO [TableName] ([ColumnName])
VALUES ([VALUES])
ELSE
INTO [TableName] ([ColumnName])
VALUES ([VALUES])
SELECT [ColumnName] FROM [TableName];
但我不想从另一个表提供值,我只是想手动输入它们,所以我有:
INSERT
WHEN EXISTS (SELECT 1 FROM FOO WHERE NAME = 'JOE')
THEN
INTO BAR (NAME, AGE)
VALUES ('JOE', 50)
这将产生异常:ORA-00928:缺少SELECT关键字。
如果在另一个表中找到给定的值,我想执行插入操作。
WHEN
子句不是SQL INSERT子句的一部分:https://docs.oracle.com/database/121/SQLRF/statements_9014.htm#SQLRF01604 - user330315