当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《如何在Oracle中有条件地插入?》经验,为你挑选了1个好方法。

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

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关键字.

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



1> hkutluay..:

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

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

推荐阅读
虎仔球妈_459
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有