ITPub博客

首页 > Linux操作系统 > Linux操作系统 > oracle之merge语法(转载)

oracle之merge语法(转载)

原创 Linux操作系统 作者:star_guan2008 时间:2008-03-26 15:09:36 0 删除 编辑

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

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10742223/viewspace-217955/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2008-02-19

  • 博文量
    82
  • 访问量
    107207