SQL2008同Oracle的Merge用法比较

2023-10-17 06:38

本文主要是介绍SQL2008同Oracle的Merge用法比较,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以下测试环境 SQL 2008 同Oracle 10G
SQL2008:

USE tempdb;
GO
IF OBJECT_ID (N'Target', N'U') IS NOT NULL DROP TABLE dbo.Target;
GO
Create table Target(ID int ,Name nvarchar(10))
insert into Target
values(1,'a'),(3,'b'),
(5,'c'),(10,'d')GO
IF OBJECT_ID (N'dbo.Source', N'U') IS NOT NULL DROP TABLE dbo.Source;
GO
Create table Source(ID int ,Name nvarchar(10))
insert into Source
values(2,'E'),(4,'F'),
(6,'H'),(10,'I')/*Target--源表ID	Name
1	a
3	b
5	c
10	d
*//*Source--目标表
ID	Name
2	E
4	F
6	H
10	I
*/go
begin tran
merge Target as T
using Source as S
on (T.ID=S.ID)
when matched and T.Name<>S.Name					--ID相同,Name不同时更新then update set T.Name=S.Name
when not matched  then					--这里可不用写by Target(not matched by Target )没有的ID,新增insert (ID,Name)values(S.ID,S.Name)
when not matched by source then			--删除Target表在Source表没有的记录delete
OUTPUT $action, inserted.ID AS SourceID, inserted.Name AS SourceName, deleted.ID AS TargetID, deleted.Name AS TargetName;select * from Target
select * from Sourcerollback tran
/*$action
$action	SourceID	SourceName	TargetID	TargetName
INSERT	2	E	NULL	NULL
INSERT	4	F	NULL	NULL
INSERT	6	H	NULL	NULL
DELETE	NULL	NULL	1	a
DELETE	NULL	NULL	3	b
DELETE	NULL	NULL	5	c
UPDATE	10	I	10	dTarget
ID	Name
10	I
2	E
4	F
6	HSource
ID	Name
2	E
4	F
6	H
10	I*/
go

Oracle环境:
/**删除表
begin
execute immediate ' drop table Target';
exception when others then
null;
end;begin
execute immediate ' drop table Source';
exception when others then
null;
end;
**/Create table Target(ID int ,Name varchar2(10));
insert into Target values(1,'a');
insert into Target values(3,'b');
insert into Target values(5,'c');
insert into Target values(10,'d');Create table Source(ID int ,Name varchar2(10));
insert into Source values(2,'E');
insert into Source values(4,'F');
insert into Source values(6,'H');
insert into Source values(10,'I');/**Merge Into 语句代替Insert/Update**/
MERGE INTO Target  T   USING Source  S   ON (T.ID = S.ID)   WHEN MATCHED THEN  UPDATE  SET T.Name = S.NameWHERE T.Name<>S.Name WHEN NOT MATCHED THEN  INSERT  VALUES (S.ID, S.Name);/**删除不存在Source表记录**/
delete Target where not exists(select 1 from Source where ID=Target.ID);

/**--两表结果
Target/Source
ID	NAME
10	I
6	H
4	F
2	E
**/


这篇关于SQL2008同Oracle的Merge用法比较的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/223602

相关文章

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Java中Scanner的用法示例小结

《Java中Scanner的用法示例小结》有时候我们在编写代码的时候可能会使用输入和输出,那Java也有自己的输入和输出,今天我们来探究一下,对JavaScanner用法相关知识感兴趣的朋友一起看看吧... 目录前言一 输出二 输入Scanner的使用多组输入三 综合练习:猜数字游戏猜数字前言有时候我们在

java解析jwt中的payload的用法

《java解析jwt中的payload的用法》:本文主要介绍java解析jwt中的payload的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解析jwt中的payload1. 使用 jjwt 库步骤 1:添加依赖步骤 2:解析 JWT2. 使用 N

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

python3 gunicorn配置文件的用法解读

《python3gunicorn配置文件的用法解读》:本文主要介绍python3gunicorn配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python3 gunicorn配置文件配置文件服务启动、重启、关闭启动重启关闭总结python3 gun

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(

C#中DrawCurve的用法小结

《C#中DrawCurve的用法小结》本文主要介绍了C#中DrawCurve的用法小结,通常用于绘制一条平滑的曲线通过一系列给定的点,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 如何使用 DrawCurve 方法(不带弯曲程度)2. 如何使用 DrawCurve 方法(带弯曲程度)3.使用Dr