oracle中MERGE语句和多表关联的update简析-Oracle

Oracle 21NN 4个月前 (06-24) 13次浏览 已收录 0个评论 扫描二维码

MERGE是用来一次操作实现INSERT,UPDATE,DELETE的复合语句。

 

语法:

MERGE INTO TABLE/VIEW USING (TABLE/VIEW/SUBQUERY) ON (condition)

[WHEN METCHED THEN UPDATE SET COLUMN=expr/DEFAULT [WHERE condition]

     www.2cto.com       [DELETE  WHERE condition]]

[WHEN NOT MATCHED THEN INSERT [(column,…)] VALUES(v,…) [WHERE condition]]

[LOG ERRORS [ INTO TABLE (…)] [REJECT LIMIT num/UNLIMITED]]

 

说明:

1、更新视图时不能使用DEFAULT值。

2、不能更新ON中的关联字段。

例子:

1

MERGE INTO bonuses D

2

   USING (SELECT employee_id, salary, department_id FROM employees

3

   WHERE department_id = 80) S

4   http://www.2cto.com  

   ON (D.employee_id = S.employee_id)

5

   WHEN MATCHED THEN UPDATE SET D.bonus = D.bonus + S.salary*.01

6

     DELETE WHERE (S.salary > 8000)

7

   WHEN NOT MATCHED THEN INSERT (D.employee_id, D.bonus)

8

     VALUES (S.employee_id, S.salary*0.1)

9

     WHERE (S.salary <= 8000);

在update语句中,通常只能update一张表,对于多表关联更新,update语句限制关联字段必须有惟一索引。

例如:

1

update (select a.city_name,b.city_name as new_name

2

from customers a,

3

tmp_cust_city b

4  www.2cto.com  

where b.customer_id=a.customer_id

5

)

6

set city_name=new_name

现在,可以使用merge来实现这个功能:

 

1

MERGE INTO a USING b  ON (b.customer_id=a.customer_id )

2

   WHEN MATCHED THEN UPDATE SET a.city_name=b.city_name

 

 

 

作者 hulubo


本文:oracle中MERGE语句和多表关联的update简析-Oracle 本文链接:https://www.21nn.cn/shujuku/oracle/40253.html 本站所以图片、文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如有侵权请邮件与我们联系处理。i@ki4.cn
喜欢 (0)
[1353713598@qq.com]
分享 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址