SQL Server merge用法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了SQL Server merge用法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2012字,纯文字阅读大概需要3分钟。
内容图文
![SQL Server merge用法](/upload/InfoBanner/zyjiaocheng/513/50a5f29e835a4c7ca71822fafb230688.jpg)
下图,说明了 source 表和 target 表 的一些操作:插入,更新,删除:
如果单独使用 INSERT, UPDATE和DELETE语句,则需要三个单独的语句,来使 source 表中的匹配行的数据更新到 target表。
但是,使用 merge 可以同时执行三个操作。下面是 merge语句的语法:
MERGE target_table USING source_table
ON merge_condition
WHEN MATCHED
THEN update_statement
WHEN NOT MATCHED
THEN insert_statement
WHEN NOT MATCHED BY SOURCE
THEN DELETE;
使用示例:
CREATE TABLE sales.category ( category_id INT PRIMARY KEY, category_name VARCHAR(255) NOT NULL, amount DECIMAL(10 , 2 ) ); INSERT INTO sales.category(category_id, category_name, amount) VALUES(1,‘Children Bicycles‘,15000), (2,‘Comfort Bicycles‘,25000), (3,‘Cruisers Bicycles‘,13000), (4,‘Cyclocross Bicycles‘,10000); CREATE TABLE sales.category_staging ( category_id INT PRIMARY KEY, category_name VARCHAR(255) NOT NULL, amount DECIMAL(10 , 2 ) ); INSERT INTO sales.category_staging(category_id, category_name, amount) VALUES(1,‘Children Bicycles‘,15000), (3,‘Cruisers Bicycles‘,13000), (4,‘Cyclocross Bicycles‘,20000), (5,‘Electric Bikes‘,10000), (6,‘Mountain Bikes‘,10000);
要使用 sales.category_staging(源表)中的值将数据更新到 sales.category(目标表),要使用 merge:
MERGE sales.category t USING sales.category_staging s ON (s.category_id = t.category_id) WHEN MATCHED THEN UPDATE SET t.category_name = s.category_name, t.amount = s.amount WHEN NOT MATCHED BY TARGET THEN INSERT (category_id, category_name, amount) VALUES (s.category_id, s.category_name, s.amount) WHEN NOT MATCHED BY SOURCE THEN DELETE;
执行过程如下图:
SQL Server merge用法
标签:操作 存在 oss src stat key upd let table
本文系统来源:https://www.cnblogs.com/Vincent-yuan/p/11521229.html
内容总结
以上是互联网集市为您收集整理的SQL Server merge用法全部内容,希望文章能够帮你解决SQL Server merge用法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。