oracle merge into 用法詳解


1.    MERGE INTO 的用途
         MERGE INTO 是Oracle 9i以后才出現的新的功能。那這個功能 是什么呢?
         簡單來說,就是:“有則更新,無則插入”
         從這句話里,應該可以理解到,merge into 操作一個對象'A'的時候,要有另外一個結果集做為源數據 'B'.
         ‘merge into’  將B中的數據與A中的數據按照一定條件'C'進行對比,如果 A中數據滿足C條件,則進行update操作,如果不滿足條件 'C',則進行insert操作。(請注意這種對應關系)

2、 語法結構
      
       MERGE [INTO] [schema.]table [alias]
       USING {[schema.]table|views|query} [alias]
       ON {condition}
       WHEN MATCHED THEN UPDATE SET {clause}
       WHEN NOT MATCHED THEN INSERT VALUES {clause}
     
       我們可以用於單條數據的處理,也可以用於數據的批處理。對於merge into來說,那都是張飛吃豆芽兒,小菜一碟兒。而且效率要比單獨執行update+insert 操作效率要高。
    但是請注意,using語句中的結果集 B不可以與merge into 的對象A相同,否則,會因為結果集A,B恆等。

當 on() 進行等值判斷時,只可以進行update操作,不能進行insert 操作,當 on() 進行不等值判斷時,只可以進行insert操作,不能進行update操作。

首先創建示例表:
create table PRODUCTS
    (
    PRODUCT_ID INTEGER,
    PRODUCT_NAME VARCHAR2(60),
    CATEGORY VARCHAR2(60)
    );

    insert into PRODUCTS values (1501, 'VIVITAR 35MM', 'ELECTRNCS');
    insert into PRODUCTS values (1502, 'OLYMPUS IS50', 'ELECTRNCS');
    insert into PRODUCTS values (1600, 'PLAY GYM', 'TOYS');
    insert into PRODUCTS values (1601, 'LAMAZE', 'TOYS');
    insert into PRODUCTS values (1666, 'HARRY POTTER', 'DVD');
    commit;

    create table NEWPRODUCTS
    (
    PRODUCT_ID INTEGER,
    PRODUCT_NAME VARCHAR2(60),
    CATEGORY VARCHAR2(60)
    );

    insert into NEWPRODUCTS values (1502, 'OLYMPUS CAMERA', 'ELECTRNCS');
    insert into NEWPRODUCTS values (1601, 'LAMAZE', 'TOYS');
    insert into NEWPRODUCTS values (1666, 'HARRY POTTER', 'TOYS');
    insert into NEWPRODUCTS values (1700, 'WAIT INTERFACE', 'BOOKS');
   commit;

 

1.可省略的UPDATE或INSERT子句

update使用,省略insert:

MERGE INTO products p
   USING newproducts np
   ON (p.product_id = np.product_id)
   WHEN MATCHED THEN
   UPDATE
   SET p.product_name = np.product_name,
   p.category = np.category;

insert使用,省略update:MERGE INTO products p
    USING newproducts np
    ON (p.product_id = np.product_id)
    WHEN NOT MATCHED THEN
    INSERT
    VALUES (np.product_id, np.product_name,np.category);

2、帶條件的Updates和Inserts子句

你能夠添加WHERE子句到UPDATE或INSERT子句中去, 來跳過update或insert操作對某些行的處理.

下面例子根據表NEWPRODUCTS來更新表PRODUCTS數據,根據條件category進行更新

MERGE INTO products p
  USING newproducts np
  ON (p.product_id = np.product_id)
   WHEN MATCHED THEN
   UPDATE
   SET p.product_name = np.product_name
  WHERE p.category = np.category;

 

MERGE INTO products p
 USING newproducts np
 ON (p.product_id = np.product_id)
 WHEN MATCHED THEN
 UPDATE
 SET p.product_name = np.product_name,
 p.category = np.category
WHERE p.category = 'DVD'
WHEN NOT MATCHED THEN
INSERT
VALUES (np.product_id, np.product_name, np.category)
WHERE np.category != 'BOOKS'

 

3.兩表連接無條件的Inserts
你能夠不用連接源表和目標表就把源表的數據插入到目標表中. 這對於你想插入所有行到目標表時是非常有用的. Oracle 10g現在支持在ON條件中使用常量過濾謂詞. 舉個常量過濾謂詞例子ON (1=0). 下面例子從源表插入行到表PRODUCTS, 不檢查這些行是否在表PRODUCTS中存在:

 

SQL> MERGE INTO products p
    USING newproducts np
   ON (1=0)
   WHEN NOT MATCHED THEN
   INSERT
   VALUES (np.product_id, np.product_name, np.category)
   WHERE np.category = 'BOOKS'

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM