首页 > 数据库技术 > 详细

简化SQL计算之编写动态MERGE语句

时间:2015-07-01 02:09:11      阅读:309      评论:0      收藏:0      [点我收藏+]

? ? ? ? ?MSSQLORACLE等数据库支持MERGE语句更新表,但表结构未知时,由于缺乏集合类数据,用存储过程获得表结构再动态拼出SQL非常麻烦,代码会有几十行之多;同样原因,用Java等高级语言实现也不简单。而且使用存储过程或Java程序需要代码将内置于数据库或应用程序中,更新管理较为麻烦。这时候可用集算器来协助处理,代码可置于数据库和应用程序之外,不影响数据库与应用程序的结构,易于维护。

???????? 参数sourcetarget代表两个结构相同但数据不同的表,要求以主键为标准用source更新target,比如table1table2的主键都是AB,数据如下:

bubuko.com,布布扣

?

? ? ? ? ?table2更新table1时,MERGE语句应当如下:

MERGE INTO table1 as t
USING table2 as s
ON t.A=s.A and t.B=s.B
WHEN MATCHED
THEN UPDATE SET t.C=s.C,t.D=s.D
WHEN NOT MATCHED
THEN INSERT VALUES(s.A,s.B,s.C,s.D)

?

???????? 更新后table1应当如下:


bubuko.com,布布扣
?

? ?集算器代码:


bubuko.com,布布扣
?
?

? ? ? ? A1,A2: 从系统表中读出表source的主键存入变量pks,计算结果为集合[”A”,”B”]。各种数据库获得主键的方法不同,这里以MSSQL为例。

? ? ? ??A3,A4:读出source的完整字段,columns的计算结果为[”A”,”B”,”C”,”D”]

? ? ? ??A5:动态生成MERGE语句。pks.(…)是循环函数,可对集合(包括结果集)的成员依次计算,计算中可用~引用循环变量,用#引用循环计数。

? ? ? ??A6:执行MERGE语句。
?

简化SQL计算之编写动态MERGE语句

原文:http://datamachine.iteye.com/blog/2223005

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!