今天在ITPUB上看到一个帖子:http://www.itpub.net/showthread.php?s=&postid=2123518#post2123518
根据错误提示,测试了半天才找到问题的原因:
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: 无法在源表中获得一组稳定的行