网站首页 > 资源文章 正文
使用 UPDATE 批量更新大量的数据,会出现效率低下,有时候甚至卡死的情况,后面通过使用 MERGE INTO 代替 UPDATE 执行批量更新,会提升执行效率。
原理:因为 UPDATE 关联子查询写法,是选到一条做一次子查询,这种写法得更新少,走好的索引才行,MERGE 写法是执行完 ON 后一次性更新,效率会好点。
语法:
MERGE INTO table_name alias1
USING (table|view|sub_query) alias2
ON (join condition)
WHEN MATCHED AND 限制条件 THEN --目标表存在,源表存在
UPDATE table_name
SET col1 = col_val1,
col2 = col2_val
WHEN NOT MATCHED AND 限制条件 THEN --目标表存在,源表不存在
INSERT (column_list) VALUES (column_values)
WHEN NOT MATCHED AND 限制条件 THEN SOURCE THEN --目标表存在,源表不存在
DELETE--删除目标表数据;接操作语句自定义
OUTPUT $ACTION AS [ACTION],
Insterted.id as 插入的id,
Insterted.[DESC] as 插入的DESC,
deleted.id as 删除的id,
deleted.[DESC] as 删除的DESC;
简单示例:
MERGE INTO TEST_MERGE_INTO T1
USING TEST_MERGE_INTO_DETAIL T2
ON (T1.ID = T2.ID)
WHEN MATCHED THEN
UPDATE SET ITEM_NAME = T2.ITEM_NAME
WHEN NOT MATCHED THEN
INSERT (ID, ITEM_NO, ITEM_NAME) VALUES (1, '031', 'api');
COMMIT;
猜你喜欢
- 2024-10-10 Oracle序列Sequence的基本使用(序列 oracle)
- 2024-10-10 oracle 数据库高效批量更新操作 MERGE INTO
- 2024-10-10 详解Oracle 11g如何快速定位到lobsegment、lobindex对应的表
- 2024-10-10 云贝教育 | Oracle 19c OCP数据库培训课,上课啦
- 2024-10-10 数据库(Oracle)序列(Sequence)的基本使用
- 2024-10-10 QT5.14.1+Win7 64+Oracle11gR2 Qt连接数据库
- 2024-10-10 Oracle数据库字符集概述及修改方式
- 2024-10-10 Oracle数据库字符集概述及修改方式记录
- 2024-10-10 大牛OCM视频教程 全套 Oracle视频教程
- 2024-10-10 新福利!数据库之Oracle教学视频及电子书籍!进来了资料都是你的
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 电脑显示器花屏 (79)
- 403 forbidden (65)
- linux怎么查看系统版本 (54)
- 补码运算 (63)
- 缓存服务器 (61)
- 定时重启 (59)
- plsql developer (73)
- 对话框打开时命令无法执行 (61)
- excel数据透视表 (72)
- oracle认证 (56)
- 网页不能复制 (84)
- photoshop外挂滤镜 (58)
- 网页无法复制粘贴 (55)
- vmware workstation 7 1 3 (78)
- jdk 64位下载 (65)
- phpstudy 2013 (66)
- 卡通形象生成 (55)
- psd模板免费下载 (67)
- shift (58)
- localhost打不开 (58)
- 检测代理服务器设置 (55)
- frequency (66)
- indesign教程 (55)
- 运行命令大全 (61)
- ping exe (64)
本文暂时没有评论,来添加一个吧(●'◡'●)