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: 无法在源表中获得一组稳定的行
- oracle之merge语法
- Oracle Merge语法
- Oracle Merge语法
- Oracle Merge语法使用记录
- Oracle的Merge into语法
- Oracle merge into delete语法
- Oracle语法:merge into using
- Oracle merge into语法简介
- Oracle 之 MERGE INTO
- oracle表数据同步 merge语法
- Oracle之merge误区讨论
- Oracle之merge经典案例
- merge语法
- merge语法
- Oracle语法之OVER
- Oracle高级应用之合并MERGE
- Oracle高级应用之合并MERGE
- oracle 之 merge into 的用法
- 汉字与区位码之间的互相转换
- 我的专题文章之二----对中断的总结
- 用jfreechat编写图形化统计数据程序(实例)
- 使用SQL完成hibernate saveOrUpdate功能
- 单向链表的节点删除
- oracle之merge语法
- 刘涛涛题目,无聊写了下
- 深入GetMessage和PeekMessage
- 第一篇啊
- 487-3279 - PKU 1002
- 鞋好久没有穿坏过了
- 因为有了老狼,老虎,我们不在是兔子.
- Google Gears
- asp.net利用RAR实现文件压缩解压缩【月儿原创】