数据库|mysql教程
merge,into
数据库-mysql教程
android 电台源码,vscode 地址标记,ubuntu查看程序内存泄漏,ide集成tomcat,sqlite表格出现null,手机折线图插件,字节跳动开源前端框架,爬虫学习哪个好,post get php,seo蜘蛛侠破解版,织梦美女图片网站源码下载,魔方块网页,dsicuz模板,浮动按钮 会卡死在滚动页面,网上书店管理系统 7.1 下载,微赞小程序前端后端安装lzw
昨晚更新了一批数据,用update的老办法耗时20多分,而用mergeinto不到2秒结束,效率真是天壤之别。具体见下:用T_TMP_SCHOOL(135868行)的BIRTH字段更新T_TMP_N
易语言qq登录验证源码,vscode 不能联网,ubuntu安装阿里云盘,tomcat 免费ssl,sqlite3 计数,在线预览doc 前端插件,jsp可用的前端框架,爬虫怎么输出语句,php 继承类,山西SEO优化电池,仿微拍视频网站源码,.net 网页聊天,js三级筛选模板,京东店铺手机活动页面,内容管理系统 源码 php,java 用户登录程序lzw
扫码付款下载网站源码,ubuntu配置地址命令,解压版tomcat9配置,爬虫计划是什么,php的词法结构是什么啊,seo网页指纹lzw
昨晚更新了一批数据,用update的老办法耗时20多分,而用 merge into 不到2秒结束,效率真是天壤之别。具体见下:
用T_TMP_SCHOOL(135868行)的BIRTH 字段更新T_TMP_NT_CUSTOMERDETAIL( 763119行) 的BIRTHDATE 字段,连接条件 T_TMP_SCHOOL.ID = t_tmp_nt_customerdetail.SCHOOLID
–表结构
create table T_TMP_NT_CUSTOMERDETAIL
(
CUSTOMERID VARCHAR2(15) not null,
DOCCATEGORY VARCHAR2(2) not null,
DOCNUMBERVARCHAR2(20) not null,
BIRTHDATEVARCHAR2(8),
………..
SCHOOLID VARCHAR2(60)
);
create table T_TMP_SCHOOL
(
IDVARCHAR2(20),
COMPANY VARCHAR2(100),
NAME VARCHAR2(20),
BIRTH VARCHAR2(20)
);
–两个表的数据见下:
select count(1) from t_tmp_nt_customerdetail t; –763119
select count(1) from t_tmp_school; –135868
–为了验证结果,测试前先清空birthdate的值,网站空间,共更改 135879 行
update t_tmp_nt_customerdetail t
set t.birthdate = null
where t.schoolid is not null;
—实现的过程:
create or replace procedure p_tmp_update_customerdetail
is
v_BeginTran INT := 0; — 事务标志,初始值为0,香港空间,表示没有事务
v_ErrCode INT;
v_ErrMsg VARCHAR2(200); — 处理异常变量
begin
— 设置事务标志为1,表示开始事务
v_BeginTran := 1;
merge into t_tmp_nt_customerdetail t
using (select b.id, b.birth from t_tmp_school b where b.birth is not null) a
on (t.schoolid = a.id)
when matched then
update set t.birthdate = a.birth where t.schoolidis not null;
COMMIT;
— 提交事务并且置事务标志为0。
v_BeginTran := 0;
EXCEPTION
WHEN OTHERS THEN
— 如果异常,回滚事务。
IF v_BeginTran = 1 THEN
ROLLBACK;
END IF;
v_ErrCode := SQLCODE;
v_ErrMsg := SUBSTR(SQLERRM, 1, 150);
dbms_output.put_line(v_ErrCode);
dbms_output.put_line(v_ErrMsg);
end;
–执行过程,用时1.11秒
SQL> exec p_tmp_update_customerdetail;
–再次验证结果,先前清空birthdate的值已经有了,返回 135879 行
select count(1) from t_tmp_nt_customerdetail t
where t.schoolid is not null
and t.birthdate is not null;
–而用下面类似的语句,这些数据执行了24分钟多:
update t_tmp_nt_customerdetail t
set t.birthdate = (select b.birth
from t_tmp_school b
where t.schoolid = b.id)
where t.schoolid =
(select c.id from t_tmp_school c where t.schoolid = c.id)
and t.schoolid is not null;—注:为什么要写这个罗嗦的条件呢?因为没有这个条件就把整个表的数据全部更新了,因此必须写,虚拟主机,所以大家应该多实践,不要被一些表面现象所蒙蔽。
本文出自 “srsunbing” 博客,请务必保留此出处