teradata 数据库的merge 语句

teradata 数据库的merge 语句,第1张

需求:

将t2表的数据插入t1,当t2的a2值存在a1中时,使用t2的数据更新t1的数据,当a2的值不存在时,直接插入t1表

结果:可以使用Merge来实现此功能,测试如下:

CREATE TABLE dwsdata.t1 (

a1 INTEGER,

b1 INTEGER,

c1 INTEGER)

CREATE TABLE dwsdata.t2 (

a2 INTEGER,

b2 INTEGER,

c2 INTEGER)

select * from dwsdata.t1

a1 b1 c1

1 1 1

2 2 2

3 3 3

select * from dwsdata.t2

a2 b2 c2

1 2 2

2 3 3

4 5 5

MERGE INTO t1

USING t2

ON a1 = a2

WHEN MATCHED THEN

UPDATE SET b1 = b2,c1 = c2

WHEN NOT MATCHED THEN

INSERT (a2, b2, c2)

预期结果:

1 2 2

2 3 3

3 3 3

4 5 5

select * from dwsdata.t1

a1 b1 c1

1 2 2

2 3 3

3 3 3

4 5 5

merge 是sqlserver2008的新语句

SQL Server 2008将包含用于合并两个行集(rowset)数据的新句法。根据一个源数据表对另一个数据表进行确定性的插入、更新和删除这样复杂的 *** 作,运用新的MERGE语句,开发者用一条命令就可以完成。

对两个表进行信息同步时,有三步 *** 作要进行。首先要处理任何需要插入目标数据表的新行。其次是处理需要更新的已存在的行。最后要删除不再使用的旧行。这个过程中需要维护大量重复的逻辑,并可能导致微妙的错误。

Bob Beauchemin讨论了MERGE语句,这个语句将上述的多个 *** 作步骤合并成单一语句。他给出了如下的例子:

merge [target] t  

using [source] s on t.id = s.id  

when matched then update set t.name = s.name, t.age = s.age -- use "rowset1"  

when not matched then insert values(id,name,age) -- use "rowset2"  

when not matched  by source then delete -- use "rowset3" 

如你所见,具体 *** 作是根据后面的联合(join)的解析结果来确定的。在这个例子中,如果目标和源数据表有匹配的行,就实行更新 *** 作。如果没有,就实行插入或者删除 *** 作来使目标数据表和源数据表保持一致。

这个新句法的一个美妙之处是它在处理更新时的确定性。在使用标准的UPDATE句法和联合时,可能有超过一个源行跟目标行匹配。在这种情况下,无法预料更新 *** 作会采用哪个源行的数据。

而当使用MERGE句法时,如果存在多处匹配,它会抛出一个错误。这就提醒了开发者,要达到预想的目标,当前的联合条件还不够明确。

至于 ppt 没有

有本pdf http://ishare.iask.sina.com.cn/f/16236919.html

MERGE语句是SQL语句的一种。在SQL Server、Oracle数据库中可用,MySQL、PostgreSQL中不可用。MERGE是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。通过MERGE语句,根据一张表(原数据表,source table)或子查询的连接条件对另外一张(目标表,target table)表进行查询,连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9933447.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存