Oracle 使用MERGE INTO 语句更新数据

Merge into 详细介绍
MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句。
通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询,
连接条件匹配上的进行UPDATE,无法匹配的执行INSERT。
这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE。

-- 语法
MERGE [INTO [schema .] table [t_alias]
USING [schema .] { table | view | subquery } [t_alias]
ON ( condition )
WHEN MATCHED THEN merge_update_clause
WHEN NOT MATCHED THEN merge_insert_clause;
merge into users
using doctor
on (users.user_id = doctor.doctorid)
when matched then
  update set users.user_name = doctor.doctorname
when not matched then
  insert
  values
    (doctor.doctorid,
     doctor.doctorid,
     '8736F1C243E3B14941A59FF736E1B5A8',
     doctor.doctorname,
     sysdate,
     'T',
     ' ',
     doctor.deptid,
     'b319dac7-2c5c-496a-bc36-7f3e1cc066b8');

原文地址:http://www.cnblogs.com/jiangguang/archive/2012/12/24/2830581.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`MERGE INTO` 是 Oracle 数据库中的一种语法,用于将一个表中的数据合并到另一个表中。它可以根据某些条件来判断是执行插入操作还是更新操作。 `MERGE INTO` 语句的基本语法如下: ``` MERGE INTO table1 USING table2 ON (condition) WHEN MATCHED THEN UPDATE SET column1 = value1, column2 = value2,... WHEN NOT MATCHED THEN INSERT (column1, column2,...) VALUES (value1, value2,...); ``` 其中,`table1` 是要被更新或插入数据的目标表,`table2` 是要合并到目标表的源表,`condition` 是用于匹配目标表和源表记录的条件。 当匹配成功时,`UPDATE` 子句将更新目标表中的记录。`WHEN NOT MATCHED` 子句将在目标表中没有匹配记录时执行插入操作。 以下是一个简单的例子,假设有两个表 `employees` 和 `employee_updates`,需要将 `employee_updates` 中的数据合并到 `employees` 表中: ``` MERGE INTO employees e USING employee_updates eu ON (e.employee_id = eu.employee_id) WHEN MATCHED THEN UPDATE SET e.salary = eu.salary WHEN NOT MATCHED THEN INSERT (e.employee_id, e.first_name, e.last_name, e.salary) VALUES (eu.employee_id, eu.first_name, eu.last_name, eu.salary); ``` 以上语句将根据 `employee_id` 来匹配 `employees` 表和 `employee_updates` 表的记录,如果匹配成功,则将 `employees` 表中相应记录的 `salary` 字段更新为 `employee_updates` 表中相应记录的 `salary` 字段。如果匹配不成功,则将 `employee_updates` 表中的记录插入到 `employees` 表中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值