1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 更新语句的效率比较(merge into )

更新语句的效率比较(merge into )

时间:2020-01-10 17:54:10

相关推荐

更新语句的效率比较(merge into )

数据库|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” 博客,请务必保留此出处

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。