数据库高效批量更新操作 MERGE INTO

打印 上一主题 下一主题

主题 906|帖子 906|积分 2718

使用 UPDATE 批量更新大量的数据,会出现效率低下,有时候甚至卡死的情况,后面通过使用 MERGE INTO 代替 UPDATE 执行批量更新,会提升执行效率。
原理:因为 UPDATE 关联子查询写法,是选到一条做一次子查询,这种写法得更新少,走好的索引才行,MERGE 写法是执行完 ON 后一次性更新,效率会好点。
语法:
  1. MERGE INTO table_name alias1
  2. USING (table|view|sub_query) alias2
  3. ON (join condition)
  4. WHEN MATCHED AND 限制条件 THEN  --目标表存在,源表存在
  5. UPDATE table_name
  6. SET col1 = col_val1,
  7. col2 = col2_val
  8. WHEN NOT MATCHED AND 限制条件 THEN  --目标表存在,源表不存在
  9. INSERT (column_list) VALUES (column_values)
  10. WHEN NOT MATCHED AND 限制条件 THEN SOURCE THEN --目标表存在,源表不存在
  11. DELETE--删除目标表数据;接操作语句自定义
  12. OUTPUT $ACTION AS [ACTION],
  13. Insterted.id as 插入的id,
  14. Insterted.[DESC] as 插入的DESC,
  15. deleted.id as 删除的id,
  16. deleted.[DESC] as 删除的DESC;
复制代码
简单示例:
  1. MERGE INTO TEST_MERGE_INTO T1
  2. USING TEST_MERGE_INTO_DETAIL T2
  3. ON (T1.ID = T2.ID)
  4. WHEN MATCHED THEN
  5.   UPDATE SET ITEM_NAME = T2.ITEM_NAME
  6. WHEN NOT MATCHED THEN
  7.   INSERT (ID, ITEM_NO, ITEM_NAME) VALUES (1, '031', 'api');
  8. COMMIT;
复制代码
 
  

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

用户云卷云舒

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表