当前位置:Gxlcms > 数据库问题 > 简化动态MERGE的SQL计算

简化动态MERGE的SQL计算

时间:2021-07-01 10:21:17 帮助过:15人阅读

        參数source和target代表两个结构同样但数据不同的表,要求以主键为标准用source更新target,比方table1和table2的主键都是A和B,数据例如以下:

技术分享

   用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应当例如以下:

技术分享    集算器代码:

技术分享

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

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

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

   A6:运行MERGE语句。


简化动态MERGE的SQL计算

标签:http   完整   line   语句   依次   family   方法   code   结构   

人气教程排行