Oracle写merge语录,oracle中MERGE语句

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

语法:

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

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

[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中的关联字段。

3、MERGE INTO的视图必须是可更新视图,参看http://my.oschina.net/hulubo/blog/53570中视图的限制。

例子:

MERGE INTO bonuses D

USING (SELECT employee_id, salary, department_id FROM employees

WHERE department_id = 80) S

ON (D.employee_id = S.employee_id)

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

DELETE WHERE (S.salary > 8000)

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

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

WHERE (S.salary <= 8000);

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

例如:

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

from customers a,

tmp_cust_city b

where b.customer_id=a.customer_id

)

set city_name=new_name

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

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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值