oracle merge 更新或插入数据
2017-08-08 14:51
363 查看
主要功能
提供有条件地更新和插入数据到数据库表中
如果该行存在,执行一个UPDATE操作,如果是一个新行,执行INSERT操作
— 避免了分开更新
— 提高性能并易于使用
— 在数据仓库应用中十分有用
MERGE语句的语法如下:
[sql] view
plain copy
MERGE [hint] 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例子
[sql] view
plain copy
MERGE INTO copy_emp c
USING employees e
ON (c.employee_id=e.employee_id)
WHEN MATCHED THEN
UPDATE SET
c.first_name=e.first_name,
c.last_name=e.last_name,
c.department_id=e.department_id
WHEN NOT MATCHED THEN
INSERT VALUES(e.employee_id,e.first_name,e.last_name,
e.email,e.phone_number,e.hire_date,e.job_id,
e.salary,e.commission_pct,e.manager_id,
e.departmetn_id);
注意:on子句的使用的字段不能够用于update,即Oracle不允许更新用于连接的列。
[sql] view
plain copy
MERGE INTO MN A
USING MM B
ON(A.ID=B.ID)
WHEN MATCHED THEN
UPDATE SET A.NAME = B.NAME
WHEN NOT MATCHED THEN
INSERT VALUES(B.ID, B.NAME);
ON(A.ID=B.ID)
[sql] view
plain copy
MERGE INTO TEST T USING TEST1
ON T1.NAME = T.NAME
WHEN NOT MATCHED THEN
INSERT
(T.ID)
values(
sys_guid()
);
提供有条件地更新和插入数据到数据库表中
如果该行存在,执行一个UPDATE操作,如果是一个新行,执行INSERT操作
— 避免了分开更新
— 提高性能并易于使用
— 在数据仓库应用中十分有用
MERGE语句的语法如下:
[sql] view
plain copy
MERGE [hint] 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例子
[sql] view
plain copy
MERGE INTO copy_emp c
USING employees e
ON (c.employee_id=e.employee_id)
WHEN MATCHED THEN
UPDATE SET
c.first_name=e.first_name,
c.last_name=e.last_name,
c.department_id=e.department_id
WHEN NOT MATCHED THEN
INSERT VALUES(e.employee_id,e.first_name,e.last_name,
e.email,e.phone_number,e.hire_date,e.job_id,
e.salary,e.commission_pct,e.manager_id,
e.departmetn_id);
注意:on子句的使用的字段不能够用于update,即Oracle不允许更新用于连接的列。
[sql] view
plain copy
MERGE INTO MN A
USING MM B
ON(A.ID=B.ID)
WHEN MATCHED THEN
UPDATE SET A.NAME = B.NAME
WHEN NOT MATCHED THEN
INSERT VALUES(B.ID, B.NAME);
ON(A.ID=B.ID)
[sql] view
plain copy
MERGE INTO TEST T USING TEST1
ON T1.NAME = T.NAME
WHEN NOT MATCHED THEN
INSERT
(T.ID)
values(
sys_guid()
);
相关文章推荐
- oracle merge 更新或插入数据
- oracle使用 merge 更新或插入数据
- oracle使用merge更新或插入数据
- oracle使用 merge 更新或插入数据(总结)
- oracle使用 merge 更新或插入数据(总结)
- oracle使用 merge 更新或插入数据
- oracle利用merge更新一表的某列数据到另一表中
- oracle merge及其他方式实现存在更新不存在插入操作
- java解析oracle日志,获取指定日期后的更新和插入数据
- Oracle优化:大量数据插入或更新
- [SQL]如何使用MERGE方法有效地插入或更新数据
- PreparedStatement 批量更新,插入数据到Oracle mysql
- oracle 如何用触发器实现更新刚插入的数据集合
- 对oracle数据的的插入、更新和读取数据
- mybatis+oracle添加数据时如果数据存在就更新,如果不存在就插入
- Oracle查询优化-04插入、更新与删除数据
- Oracle实现数据不存在则插入,数据存在则更新(insert or update)
- Oracle 触发器 插入,更新,删除,数据同步,两表同步
- Oracle中merge into的使用:该命令使用一条语句从一个或者多个数据源中完成对表的更新和插入数据.
- Oracle 触发器 插入,更新,删除,数据同步,两表同步