日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時間:2024/7/23 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle merge 效率慢,更新语句的效率比较(merge into ) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

昨晚更新了一批數(shù)據(jù),用update的老辦法耗時20多分,而用 merge into 不到2秒結(jié)束,效率真是天壤之別。具體見下:

用T_TMP_SCHOOL(135868行)的BIRTH 字段更新T_TMP_NT_CUSTOMERDETAIL( 763119行) 的BIRTHDATE 字段,連接條件 T_TMP_SCHOOL.ID = t_tmp_nt_customerdetail.SCHOOLID

--表結(jié)構(gòu)

create table T_TMP_NT_CUSTOMERDETAIL

(

CUSTOMERID???????? VARCHAR2(15) not null,

DOCCATEGORY??????? VARCHAR2(2) not null,

DOCNUMBER????????? VARCHAR2(20) not null,

BIRTHDATE????????? VARCHAR2(8),

...........

SCHOOLID?????????? VARCHAR2(60)

);

create table T_TMP_SCHOOL

(

ID????? VARCHAR2(20),

COMPANY VARCHAR2(100),

NAME??? VARCHAR2(20),

BIRTH?? VARCHAR2(20)

);

--兩個表的數(shù)據(jù)見下:

select count(1) from t_tmp_nt_customerdetail t;? --763119

select count(1) from? t_tmp_school;????????????? --135868

--為了驗(yàn)證結(jié)果,測試前先清空birthdate的值,共更改 135879 行

update? t_tmp_nt_customerdetail t

set t.birthdate = null

where t.schoolid is not null;

---實(shí)現(xiàn)的過程:

create or replace procedure p_tmp_update_customerdetail

is

v_BeginTran INT := 0;??? -- 事務(wù)標(biāo)志,初始值為0,表示沒有事務(wù)

v_ErrCode?? INT;

v_ErrMsg??? VARCHAR2(200);?? -- 處理異常變量

begin

-- 設(shè)置事務(wù)標(biāo)志為1,表示開始事務(wù)

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.schoolid is not null;

COMMIT;

-- 提交事務(wù)并且置事務(wù)標(biāo)志為0。

v_BeginTran := 0;

EXCEPTION

WHEN OTHERS THEN

-- 如果異常,回滾事務(wù)。

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;

--執(zhí)行過程,用時1.11秒

SQL> exec? p_tmp_update_customerdetail;

--再次驗(yàn)證結(jié)果,先前清空birthdate的值已經(jīng)有了,返回 135879 行

select count(1) from t_tmp_nt_customerdetail t

where? t.schoolid is not null

and? t.birthdate is not? null;

--而用下面類似的語句,這些數(shù)據(jù)執(zhí)行了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;???? ---注:為什么要寫這個羅嗦的條件呢?因?yàn)闆]有這個條件就把整個表的數(shù)據(jù)全部更新了,因此必須寫,所以大家應(yīng)該多實(shí)踐,不要被一些表面現(xiàn)象所蒙蔽。

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎

總結(jié)

以上是生活随笔為你收集整理的oracle merge 效率慢,更新语句的效率比较(merge into )的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。