oracle之merge语法

来源:互联网 发布:软件体系结构 组成 编辑:程序博客网 时间:2024/04/29 13:48

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: 无法在源表中获得一组稳定的行

 
原创粉丝点击