zoukankan      html  css  js  c++  java
  • 简化动态MERGE的SQL计算

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

            參数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语句。


  • 相关阅读:
    Paxos算法理解
    JavaScript笔记
    JVM基础知识(二)
    JVM基础知识(一)
    书单
    centos6.3环境下升级python及MySQLdb的安装
    winform中button的image属性无法更改
    未能找到任何适合于指定的区域性或非特定区域性的资源
    Spring注解开发第十二讲--@Profile注解讲解
    Spring注解驱动第十一讲--引用Spring底层组件
  • 原文地址:https://www.cnblogs.com/yxysuanfa/p/7211931.html
Copyright © 2011-2022 走看看