如何在Oracle中有条件地插入?

Kam*_*mil 10 sql oracle

我在这里读到语法如下所示:

INSERT
WHEN ([Condition]) THEN
INTO [TableName] ([ColumnName])
VALUES ([VALUES])
ELSE
INTO [TableName] ([ColumnName])
VALUES ([VALUES])
SELECT [ColumnName] FROM [TableName];
Run Code Online (Sandbox Code Playgroud)

但我不想从另一个表中提供值.我只想打字,所以我有:

INSERT 
WHEN EXISTS (SELECT 1 FROM FOO WHERE NAME = 'JOE') 
THEN
INTO BAR (NAME, AGE) 
VALUES ('JOE', 50)
Run Code Online (Sandbox Code Playgroud)

这会产生异常:ORA-00928:缺少SELECT关键字.

如果在另一个表中找到给定值,我想执行插入.

hku*_*uay 9

使用选择也运行.但是关键字值存在问题

INSERT 
WHEN EXISTS (SELECT 1 FROM FOO WHERE NAME = 'JOE') 
THEN
INTO BAR (NAME, AGE) 
SELECT 'JOE', 50 FROM DUAL
Run Code Online (Sandbox Code Playgroud)


Kam*_*mil 5

所以,我在这里找到了一种间接的方法,我的问题的解决方案是:

INSERT INTO BAR (NAME, AGE) 
SELECT 'JOE', 50
  FROM DUAL
 WHERE EXISTS (SELECT 1 FROM FOO WHERE NAME = 'JOE')
Run Code Online (Sandbox Code Playgroud)

但这并不能解释为什么我必须SELECT在中使用声明INSERT WHEN