1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > ORACLE中的MERGE语法使用记录

ORACLE中的MERGE语法使用记录

时间:2021-11-25 11:08:59

相关推荐

ORACLE中的MERGE语法使用记录

项目中使用到了Oracle的MERGE INTO语句,在这里简单记录下使用方法

使用场景如下:

存在对一张数据量很大的表,你需要对里面的大量数据进行更新,如果数据不存在,就进行插入的操作。

常规想到的办法是先根据条件查询一番,如 果存在,那么就更新,否则就插入?

起始在Oracle9i 后可以用merge into轻轻松松搞定这个问题,避免多次的查询判断以及更新插入操作,而且效率更高

1.merge into简介

用来合并UPDATE和INSERT语句。通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,连接条件匹配上的进行SQL(例如UPDATE),无法匹配的执行SQL(例如INSERT)。

这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE

2.merge into语法

MERGE INTO [target-table] A USING [source-table sql] B ON([conditional expression] and [...]...)

WHEN MATCHED THEN

[UPDATE sql]

WHENNOT MATCHED THEN

[INSERT sql]

;--不要忘记分号

作用:判断B表和A表是否满足ON中条件,如果满足则执行对应sql语句,如果不满足,则执行对应sql语句

另外有说明如下:

Merge操作的只是“操作表”,源表不会有任何变化Merge的最后结尾必须是以分号结束的,不能忘了分号谨记:语法严格要求关键字之间只能有一个英文空格,不能有多余的空格不一定要把两个操作都写全,可以根据实际情况

3.merge into基础示例

---创建源表Create Table OriginTable(id Int,caption VarChar(50));---创建操作表Create Table TargetTable(id Int,caption VarChar(50));--插入测试数据Insert Into OriginTable(id,caption)VALUES(1,'测试1');Insert Into OriginTable(id,caption)VALUES(2,'测试2');Insert Into OriginTable(id,caption)VALUES(3,'测试3');Insert Into OriginTable(id,caption)VALUES(4,'测试4');Insert Into TargetTable(id,caption)VALUES(1,'目标表匹配到了源表则update1');Insert Into TargetTable(id,caption)VALUES(2,'目标表匹配到了源表则update2');Select * from OriginTable;Select * from TargetTable;

MERGE INTO TargetTableUSING OriginTableON (TargetTable.id=OriginTable.id)

WHEN MATCHED --当上面on后的TargetTable.id=OriginTable.id时,则更新,也可以加上自定义的限制条件 MATCHED AND S.id=2

Then UpDate setTargetTable.caption=OriginTable.caption

When Not Matched --目标中没有的id ,在源表中有则插入

Then Insert Values(OriginTable.id, OriginTable.caption)

;--Merge的最后结尾必须是以分号结束的,不能忘了分号 谨记:语法严格要求关键字之间只能有一个英文空格,不能有多余的空格

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。