merge into用法mysql_merge into用法

merge into用法mysql_merge into用法简单的说就是,判断表中有没有符合on()条件中的数据,有了就更新数据,没有就插入数据。有一个表T,有两个字段a、b,我们想在表T中做Insert/Update,如果条件满足,则更新T中b的值,否则在T中插入一条记录。在Microsoft的SQL语法中,很简单的一句判断就可以了,SQLServer中的语法如下:(推荐学习:MySQL视频教程)ifexists(select1fromTwh…

简单的说就是,判断表中有没有符合on()条件中的数据,有了就更新数据,没有就插入数据。

e7d52ce4874a3320a7500d596c433e0e.png

有一个表T,有两个字段a、b,我们想在表T中做Insert/Update,如果条件满足,则更新T中b的值,否则在T中插入一条记录。在Microsoft的SQL语法中,很简单的一句判断就可以了,SQL Server中的语法如下:(推荐学习:MySQL视频教程)if exists(select 1 from T where T.a=’1001′ )

update T set T.b=2 Where T.a=’1001′

else

insert into T(a,b) values(‘1001’,2);

但是很明显这个语法对于SQL只能更改一条语句,并且Oracle不能使用.所以就有了Merge into(Oracle 9i引入的功能)语法merge into 目标表 a

using 源表 b

on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)

when matched then update set a.更新字段=b.字段

when not matched then insert into a(字段1,字段2……)values(值1,值2……)

“在一个同时存在Insert和Update语法的Merge语句中,总共Insert/Update的记录数,就是Using语句中”源表”的记录数”。

源表b可能是一张表结构不同于a的表,有可能是一张构建相同表结构的临时表,也有可能是我们自己组起来的数据.

更多MySQL相关技术文章,请访问MySQL数据库图文教程栏目进行学习!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/36951.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注