Oracle中merge用法

企鹅博客
企鹅博客
企鹅博客
20688
文章
0
评论
2019年8月13日09:50:38 评论 997 views 1166字阅读3分53秒

MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。 通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。

语法

MERGE [INTO [schema .] table [t_alias]

  USING [schema .] { table | view | subquery } [t_alias]

  ON ( condition )

  WHEN MATCHED THEN merge_update_clause

  WHEN NOT MATCHED THEN merge_insert_clause;

1、UPDATE或INSERT子句是可选的

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

3、在ON条件中使用常量过滤谓词来insert所有的行到目标表中,不需要连接源表和目标表

4、UPDATE子句后面可以跟DELETE子句来去除一些不需要的行

首先创建示例表:

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');

继续阅读
weinxin
欢迎加入中国站长博客之家
本站的所有资源都会上传分享到博客之家,希望大家互相学习交流进步。
Red Hat Enterprise Linux6.5 下MongoDB安装 Linux-数据库

Red Hat Enterprise Linux6.5 下MongoDB安装

伴随着互联网应用的迅猛推广和各种开源产品的深入,各种非关系型数据NoSQL产品近几年的发展比较迅猛。针对特定行业、领域和应用场景,脱离关系型数据模型体系的NoSQL家族,已经逐步深入各行各业,逐步被技...
MySQL转数据到Oracle Linux-数据库

MySQL转数据到Oracle

一、首先從網絡上找到一些資料如下: 1. 自动增长的数据类型处理 MYSQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。Oracle没有自动增长的数据类型,需要建立一个自动增长的...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: