oracle之merge语法

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

SQL> CREATE TABLE MM (ID NUMBER, NAME VARCHAR2(20));

表已创建。

SQL> CREATE TABLE MN (ID NUMBER, NAME VARCHAR2(20));

表已创建。

SQL> INSERT INTO MM VALUES (1, 'A');

已创建 1 行。

SQL> INSERT INTO MN VALUES (1, 'B');

已创建 1 行。

SQL> MERGE INTO MN A
  2  USING MM B
  3  ON(A.ID=B.ID)
  4  WHEN MATCHED THEN
  5  UPDATE SET A.ID = B.ID
  6  WHEN NOT MATCHED THEN
  7  INSERT VALUES(B.ID, B.NAME);
ON(A.ID=B.ID)
   *
ERROR 位于第 3 行:
ORA-00904: "A"."ID": 无效的标识符


SQL> MERGE INTO MN A
  2  USING MM B
  3  ON(A.ID=B.ID)
  4  WHEN MATCHED THEN
  5  UPDATE SET A.NAME = B.NAME
  6  WHEN NOT MATCHED THEN
  7  INSERT VALUES(B.ID, B.NAME);

1 行已合并。

根据测试结果,发现Oracle不允许更新用于连接的列,但是错误提示却有误导的嫌疑。

而且Oracle的SQL REFERENCE手册上也没有给出这个提示。

虽然文档上有这样的描述:

MERGE is a deterministic statement. That is, you cannot update the same row of the target table multiple times in the same MERGE statement.

但是这应该是说明下面这种情况的。

当有多对一的情况出现时会出现如下错误

SQL> INSERT INTO MM VALUES (1, 'C');

已创建 1 行。

SQL> MERGE INTO MN A
  2  USING MM B
  3  ON(A.ID=B.ID)
  4  WHEN MATCHED THEN
  5  UPDATE SET A.NAME = B.NAME
  6  WHEN NOT MATCHED THEN
  7  INSERT VALUES(B.ID, B.NAME);
MERGE INTO MN A
           *
ERROR 位于第 1 行:
ORA-30926: 无法在源表中获得一组稳定的行

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值