oracle 中利用WHEN .. THEN 可以使insert into 语句更灵活

背景:

      想往一个表中插入一条记录,但是需要先判断库里有没有存在一个号码的记录,若存在则不插入,否则插入新记录。

 

SQL:

insert first
when not exists (select FID from t_ckpt_shipflow where fpostrequisitionnumber = '2010000997') then
into t_ckpt_shipflow(fid,fflowname,fpostrequisitionnumber) 
select '001002' fid,'流程名称' fflowname,'2010000997' fpostrequisitionnumber from dual

 

说明:

若 t_ckpt_shipflow 表中存在 fpostrequisitionnumber = '2010000997' 的记录时,就不在插入新记录。

 

这里用到了INSERT INTO 的另类写法,那就是 WHEN .. THEN的使用,可以使SQL更加灵活。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`INSERT INTO ... ON DUPLICATE KEY UPDATE` 和 `MERGE INTO` 都是用于在数据库进行新或插入操作的语句。 `INSERT INTO ... ON DUPLICATE KEY UPDATE` 语句用于在插入一行数据时,如果该行数据已经存在于表,则新该行数据的值,否则插入一行新数据。 例如: ``` INSERT INTO table_name (column1, column2, column3) VALUES (value1, value2, value3) ON DUPLICATE KEY UPDATE column1 = value1, column2 = value2, column3 = value3; ``` 其,如果 `(column1, column2)` 是表的主键或唯一索引,当插入 `(value1, value2, value3)` 这一行数据时,如果已经存在 `(value1, value2)` 这一行数据,则新该行数据的值为 `(value1, value2, value3)`,否则插入一行新数据。 `MERGE INTO` 语句Oracle 数据库的一种语法,用于在一个表进行插入、新和删除操作。它的语法如下: ``` MERGE INTO target_table USING source_table ON (condition) WHEN MATCHED THEN UPDATE SET column1 = value1, column2 = value2 WHEN NOT MATCHED THEN INSERT (column1, column2) VALUES (value1, value2) ``` 其,`target_table` 是目标表,`source_table` 是源表,`condition` 是连接条件,`UPDATE SET` 子句用于新目标表的数据,`INSERT` 子句用于向目标表插入新数据。 `MERGE INTO` 语句能够实现 `INSERT INTO ... ON DUPLICATE KEY UPDATE` 的功能,同时还可以进行删除操作。但需要注意的是,`MERGE INTO` 语句只能在 Oracle 数据库使用,而 `INSERT INTO ... ON DUPLICATE KEY UPDATE` 语句则可以在其他数据库使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值