oracle实现 无则insert插入,有则update更新,一条语句直接进行insert/update操作

merge into应用:实现 无则insert插入,有则update更新,一条语句直接进行insert/update操作

merge ino语法:

    MERGE INTO  table1 alias1 
          USING  (table2|view2|sub_query2) alias2
          ON  (join condition) 
      WHEN MATCHED THEN 
          UPDATE  table1 
                SET  col1 = col_val1, 
                     col2  = col2_val 
      WHEN NOT MATCHED THEN 

               INSERT (column_list) VALUES (column_values); 


--将总公司sstl的客户信息occ_file数据表和子公司sstl_dx的客户信息occ_file核对
--如果sstl_dx公司的客户信息和sstl不同,则依据sstl客户信息更新sstl_dx的客户信息
--如果sstl_dx公司没有,则将sstl的客户信息新增入sstl_dx公司
    MERGE INTO sstl_dx.occ_file dx_occ
          USING sstl.occ_file sstl_occ
          ON(dx_occ.occ01 = sstl_occ.occ01)
        WHEN MATCHED THEN
          update
            set dx_occ.occ02 = sstl_occ.occ02,
                dx_occ.occ03 = sstl_occ.occ03,
                dx_occ.occ04 = sstl_occ.occ04,
                dx_occ.occ05 = sstl_occ.occ05,
                ...
            where dx_occ.occacti = 'Y'
        WHEN NOT MATCHED THEN
          insert
            values(sstl_occ.occ01,sstl_occ.occ02,sstl_occ.occ03,sstl_occ.occ04,sstl_occ.occ05,...)
            where sstl_occ.occacti = 'Y';


猜你喜欢

转载自blog.csdn.net/lansetiankong12/article/details/78652335