Oracle9i引入了MERGE命令,你能够在一个SQL语句中对一个表同时执行inserts和updates操作. MERGE命令从一个或多个数据源中选择行来updating或inserting到一个或多个表.在Oracle 10g中MERGE有如下一些改进:
网管联盟bitsCN@com
网管网www_bitscn_com
1、UPDATE或INSERT子句是可选的
网管下载dl.bitscn.com
网管u家bitscn.net
2、UPDATE和INSERT子句可以加WHERE子句
网管u家u.bitscn@com
网管论坛bbs_bitsCN_com
3、在ON条件中使用常量过滤谓词来insert所有的行到目标表中,不需要连接源表和目标表 网管网www_bitscn_com
网管bitscn_com
4、UPDATE子句后面可以跟DELETE子句来去除一些不需要的行
网管u家bitscn.net
网管朋友网www_bitscn_net
首先创建示例表: 网管朋友网www_bitscn_net
网管网www_bitscn_com
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; 网管联盟bitsCN@com
|
1、可省略的UPDATE或INSERT子句 中国网管论坛bbs.bitsCN.com
中国网管论坛bbs.bitsCN.com
在Oracle 9i, MERGE语句要求你必须同时指定INSERT和UPDATE子句.而在Oracle 10g, 你可以省略UPDATE或INSERT子句中的一个. 下面的例子根据表NEWPRODUCTS的PRODUCT_ID字段是否匹配来updates表PRODUCTS的信息:
网管下载dl.bitscn.com
网管bitscn_com
SQL> MERGE INTO products p
2 USING newproducts np
3 ON (p.product_id = np.product_id)
4 WHEN MATCHED THEN
5 UPDATE
6 SET p.product_name = np.product_name,
7 p.category = np.category;
3 rows merged.
SQL> SELECT * FROM products;
PRODUCT_ID PRODUCT_NAME CATEGORY
---------- -------------------- ----------
1501 VIVITAR 35MM ELECTRNCS
1502 OLYMPUS CAMERA ELECTRNCS
1600 PLAY GYM TOYS
1601 LAMAZE TOYS
1666 HARRY POTTER TOYS
SQL>
SQL> ROLLBACK;
Rollback complete.
SQL> 网管bitscn_com
|
网管联盟bitsCN@com
网管u家bitscn.net
网管u家www.bitscn.net