温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么使用一条语句实现update/insert语句

发布时间:2022-01-04 09:17:37 来源:亿速云 阅读:135 作者:iii 栏目:数据库

这篇文章主要介绍“怎么使用一条语句实现update/insert语句”,在日常操作中,相信很多人在怎么使用一条语句实现update/insert语句问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用一条语句实现update/insert语句”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

应用场景: 处理业务数据时,如果数据库中存在这条记录则更新,如果不存在就更新。

实现SQL:(使用语oracle9i 之后的版本)

  1. MERGE INTO [your table-name] [rename your table here]     


  2. USING ( [write your query here] )[rename your query-sql and using just like a table]     


  3. ON ([conditional expression here] AND [...]...)     


  4. WHEN MATHED THEN [here you can execute some update sql or something else ]     


  5. WHEN NOT MATHED THEN [execute something else here ! ]

说明:

using:update/insert 的原数据,就是使用这些查到的数据进行更新或者插入操作的。所以说必须保证能够查出数据。

on:判断条件,判断外层表记录和using查出来的记录。

Merge: merge是用来更新整张表用得,使用时要小心。

使用例子:

  1. merge into tfa_alarm_act_nms a     

  2. using (select FP0,FP1,FP2,FP3,REDEFINE_SEVERITY     

  3. from tfa_alarm_status) b     

  4. on (a.fp0=b.fp0 and a.fp1=b.fp1 and a.fp2=b.fp2 and a.fp3=b.fp3)     

  5. when matched then update set a.redefine_severity=b.redefine_severity     

  6. when not matched then insert (a.fp0,a.fp1,a.fp2,a.fp3,a.org_severity,a.redefine_severity,  

  7. a.event_time  ,a.int_id)     

  8. values (b.fp0,b.fp1,b.fp2,b.fp3,b.REDEFINE_SEVERITY,b.redefine_severity,sysdate,7777778); 

解释:利用表tfa_alarm_status跟新标tfa_alarm_act_nms的b.redefine_servertify,条件是a.fp0=b.fp0 and a.fp1=b.fp1 and a.fp2=b.fp2 and a.fp3=b.fp3
如果tfa_alarm_act_nms表中没有该条件的数据就插入。

到此,关于“怎么使用一条语句实现update/insert语句”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI