Oracle基础教程之Merge into

[[197117]]

Merge into语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。

通过MERGE语句,根据一张表或多表联合查询的连接条件对另外一张表进行查询,连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。

这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。通过这个MERGE你能够在一个SQL语句中对一个表同时执行INSERT和UPDATE操作. 在 Oracle 10g中MERGE有一些新特性,后面我会介绍这些新特征。先看看MERGE语法如下:

  1. MERGE INTO TEST_NEW DM USING                     
  2. (                                                               
  3.         SELECT DATE_CD,                                         
  4.               HR_CD,                                           
  5.               DATE_HR, 
  6.               DECODE(GROUPING(CITY_ID), 1, 9999, CITY_ID) AS CITY_ID, 
  7.               DECODE(GROUPING(SYSTEM_ID), 1, -9999, SYSTEM_ID) AS SYSTEM_ID, 
  8.               SUM(GSM_REG_USERCNT) AS GSM_REG_USERCNT, 
  9.               SUM(TD_REG_USERCNT) AS TD_REG_USERCNT, 
  10.               SUM(TD_REG_USERRAT) AS TD_REG_USERRAT, 
  11.               SUM(GSM_POWERON_USERCNT) AS GSM_POWERON_USERCNT, 
  12.               SUM(TD_POWERON_USERCNT) AS TD_POWERON_USERCNT, 
  13.               SUM(TD_POWERON_USERRAT) AS TD_POWERON_USERRAT 
  14.         FROM  TEST_OLD 
  15.         GROUP BY DATE_HR, DATE_CD, HR_CD, ROLLUP(SYSTEM_ID),ROLLUP(CITY_ID) 
  16. ) TMP 
  17. ON 
  18.                 DM.DATE_CD  = TMP.DATE_CD  
  19.             AND DM.HR_CD    = TMP.HR_CD  
  20.             AND DM.CITY_ID  = TMP.CITY_ID  
  21.             AND DM.SYSTEM_ID = TMP.SYSTEM_ID 
  22. WHEN MATCHED THEN  UPDATE  SET 
  23.       DM.GSM_REG_USERCNT = TMP.GSM_REG_USERCNT, 
  24.       DM.TD_REG_USERCNT = TMP.TD_REG_USERCNT, 
  25.       DM.TD_REG_USERRAT = TMP.TD_REG_USERRAT, 
  26.       DM.GSM_POWERON_USERCNT  = TMP.GSM_POWERON_USERCNT, 
  27.       DM.TD_POWERON_USERCNT = TMP.TD_POWERON_USERCNT, 
  28.       DM.TD_POWERON_USERRAT = TMP.TD_POWERON_USERRAT, 
  29.       DM.DATE_HR = TMP.DATE_HR 
  30. WHEN NOT MATCHED THEN   
  31. INSERT 
  32.       DM.DATE_CD, 
  33.       DM.HR_CD, 
  34.       DM.DATE_HR, 
  35.       DM.CITY_ID, 
  36.       DM.SYSTEM_ID, 
  37.       DM.GSM_REG_USERCNT, 
  38.       DM.TD_REG_USERCNT, 
  39.       DM.TD_REG_USERRAT, 
  40.       DM.GSM_POWERON_USERCNT, 
  41.       DM.TD_POWERON_USERCNT, 
  42.       DM.TD_POWERON_USERRAT 
  43. VALUES 
  44. (  
  45.       TMP.DATE_CD, 
  46.       TMP.HR_CD, 
  47.       TMP.DATE_HR, 
  48.       TMP.CITY_ID, 
  49.       TMP.SYSTEM_ID, 
  50.       TMP.GSM_REG_USERCNT, 
  51.       TMP.TD_REG_USERCNT, 
  52.       TMP.TD_REG_USERRAT, 
  53.       TMP.GSM_POWERON_USERCNT, 
  54.       TMP.TD_POWERON_USERCNT, 
  55.       TMP.TD_POWERON_USERRAT); 

WHEN MATCHED THEN UPDATE SET 表示当on里面的关键字匹配上的时候,就进行修改操作。

但是值得注意的是,在做修改操作的时候,不可以修改on里面关键字的值。

WHEN NOT MATCHED THEN INSERT 表示当on里面的关键字匹配不上的时候,也就是说没有这样一条记录存在TEST_NEW表中时,就进行新增操作。

这时,做新增操作,就可以将on里面的字段进行设置值。

在ORACLE 10i中,MERGE有如下一些新特性。

1、UPDATE或INSERT子句是可选的

假如某个系统中,有个订单表,现在要求新增订单的记录都要反应到订单历史表ORDER_HISTORY中,我们可以如下写脚本:

  1. MERGE INTO ORDER_HISTORY H USING 
  2.       SELECT ORDER_ID              ,--订单编号 
  3.             CUSTOMER_ID            ,--客户编号 
  4.             EMPLOYEE_ID            ,--员工编号 
  5.             ORDER_DATE            ,--订购日期; 
  6.             REQUIRED_DATE          ,--预计到达日期 
  7.             SHIPPED_DATE          ,--发货日期 
  8.             SHIPPER                ,--运货商 
  9.             FREIGHT                ,--运费 
  10.             SHIP_NAM              ,--货主姓名; 
  11.             SHIP_ADDRESS          ,--货主地址 
  12.             SHIP_CITY              ,--货主所在城市; 
  13.             SHIP_REGION            ,--货主所在地区; 
  14.             SHIP_POSTALCODE        ,--货主邮编 
  15.             SHIP_COUNTRY            --货主所在国家 
  16.       FROM  ORDER_DTL 
  17.       WHERE TO_CHAR(ODER_DATE, 'YYYY-MM-DD') = '20110530' 
  18. ) O 
  19. ON 
  20.             O.ORDER_ID = H.ORDER_ID 
  21. )   
  22. WHEN NOT MATCHED THEN INSERT 
  23.             H.ORDER_ID              , 
  24.             H.CUSTOMER_ID            , 
  25.             H.EMPLOYEE_ID            , 
  26.             H.ORDER_DATE            , 
  27.             H.REQUIRED_DATE          , 
  28.             H.SHIPPED_DATE          , 
  29.             H.SHIPPER                , 
  30.             H.FREIGHT                , 
  31.             H.SHIP_NAM              , 
  32.             H.SHIP_ADDRESS          , 
  33.             H.SHIP_CITY              , 
  34.             H.SHIP_REGION            , 
  35.             H.SHIP_POSTALCODE        , 
  36.             H.SHIP_COUNTRY           
  37. VALUES 
  38. (           
  39.             O.ORDER_ID                , 
  40.             O.CUSTOMER_ID            , 
  41.             O.EMPLOYEE_ID            , 
  42.             O.ORDER_DATE              , 
  43.             O.REQUIRED_DATE          , 
  44.             O.SHIPPED_DATE            , 
  45.             O.SHIPPER                , 
  46.             O.FREIGHT                , 
  47.             O.SHIP_NAM                , 
  48.             O.SHIP_ADDRESS            , 
  49.             O.SHIP_CITY              , 
  50.             O.SHIP_REGION            , 
  51.             O.SHIP_POSTALCODE        , 
  52.             O.SHIP_COUNTRY<br>); 

从上可以看出,MATCHED 或NOT MATCHED是可选的。不必非得

  1. WHEN NOT MATCHED THEN UPDATE SET 
  2.   ..... 
  3.   WHEN MATCHED THEN INSERT 

2、UPDATE和INSERT子句可以加WHERE子句

现在由于需求改变,我们仅仅需要把员工1001的订单数据同步到订单历史记录表

  1. MERGE INTO ORDER_HISTORY H USING 
  2.       SELECT ORDER_ID              ,--订单编号 
  3.             CUSTOMER_ID            ,--客户编号 
  4.             EMPLOYEE_ID            ,--员工编号 
  5.             ORDER_DATE            ,--订购日期; 
  6.             REQUIRED_DATE          ,--预计到达日期 
  7.             SHIPPED_DATE          ,--发货日期 
  8.             SHIPPER                ,--运货商 
  9.             FREIGHT                ,--运费 
  10.             SHIP_NAM              ,--货主姓名; 
  11.             SHIP_ADDRESS          ,--货主地址 
  12.             SHIP_CITY              ,--货主所在城市; 
  13.             SHIP_REGION            ,--货主所在地区; 
  14.             SHIP_POSTALCODE        ,--货主邮编 
  15.             SHIP_COUNTRY            --货主所在国家 
  16.       FROM  ORDER_DTL 
  17. ) O 
  18. ON 
  19.             O.ORDER_ID = H.ORDER_ID 
  20. WHEN MATCHED THEN UPDATE    SET             
  21.             H.CUSTOMER_ID        =    O.CUSTOMER_ID      , 
  22.             H.EMPLOYEE_ID        =    O.EMPLOYEE_ID      , 
  23.             H.ORDER_DATE          =    O.ORDER_DATE        , 
  24.             H.REQUIRED_DATE      =    O.REQUIRED_DATE    , 
  25.             H.SHIPPED_DATE        =    O.SHIPPED_DATE      , 
  26.             H.SHIPPER            =    O.SHIPPER          , 
  27.             H.FREIGHT            =    O.FREIGHT          , 
  28.             H.SHIP_NAM            =    O.SHIP_NAM          , 
  29.             H.SHIP_ADDRESS        =    O.SHIP_ADDRESS      , 
  30.             H.SHIP_CITY          =    O.SHIP_CITY        , 
  31.             H.SHIP_REGION        =    O.SHIP_REGION      , 
  32.             H.SHIP_POSTALCODE    =    O.SHIP_POSTALCODE  , 
  33.             H.SHIP_COUNTRY        =    O.SHIP_COUNTRY       
  34.       WHERE O.EMPLOYEE_ID = '1001' 
  35. WHEN NOT MATCHED THEN INSERT 
  36.             H.ORDER_ID              , 
  37.             H.CUSTOMER_ID            , 
  38.             H.EMPLOYEE_ID            , 
  39.             H.ORDER_DATE            , 
  40.             H.REQUIRED_DATE          , 
  41.             H.SHIPPED_DATE          , 
  42.             H.SHIPPER                , 
  43.             H.FREIGHT                , 
  44.             H.SHIP_NAM              , 
  45.             H.SHIP_ADDRESS          , 
  46.             H.SHIP_CITY              , 
  47.             H.SHIP_REGION            , 
  48.             H.SHIP_POSTALCODE        , 
  49.             H.SHIP_COUNTRY           
  50. VALUES 
  51. (           
  52.             O.ORDER_ID                , 
  53.             O.CUSTOMER_ID            , 
  54.             O.EMPLOYEE_ID            , 
  55.             O.ORDER_DATE              , 
  56.             O.REQUIRED_DATE          , 
  57.             O.SHIPPED_DATE            , 
  58.             O.SHIPPER                , 
  59.             O.FREIGHT                , 
  60.             O.SHIP_NAM                , 
  61.             O.SHIP_ADDRESS            , 
  62.             O.SHIP_CITY              , 
  63.             O.SHIP_REGION            , 
  64.             O.SHIP_POSTALCODE        , 
  65.             O.SHIP_COUNTRY             
  66. )  WHERE O.EMPLOYEE_ID = '1001'; 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/254520.html<

(0)
运维的头像运维
上一篇2025-04-30 10:08
下一篇 2025-04-30 10:09

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注