Oracle千萬(wàn)級(jí)數(shù)據(jù)更新

需求

有t1,t2兩張表,通過A字段關(guān)聯(lián)产徊,現(xiàn)在需要在t1表新增字段B昂勒,將t2表中的字段C更新到t1表新增的字段B中。t1表數(shù)據(jù)一千二百萬(wàn)舟铜,t2表數(shù)據(jù)七百萬(wàn)戈盈。

常規(guī)方法

直接使用update來更新字段。

  --t1表新增字段B
  alter table t1 add ( B varchar2(32));
  --將t2表的字段C更新到t1表的B列中
  update t1 set B = (select C from t2 where t1.A =  t2.A);

在數(shù)據(jù)量較少的時(shí)候谆刨,這種寫法其實(shí)是沒問題的塘娶,簡(jiǎn)潔易懂。但是數(shù)據(jù)量太大的情況則不適用痴荐,在測(cè)試環(huán)境實(shí)際跑了一下血柳,一個(gè)小時(shí)都沒更新完官册,遂放棄生兆。

使用MERGE

merge into是oracle內(nèi)置函數(shù),通常用來處理insertOrUpdate的需求膝宁,如果存在數(shù)據(jù)就update鸦难,如果不存在就insert。也可以只用來更新员淫,速度很快合蔽。

   --t1表新增字段B
    alter table t1 add ( B varchar2(32));
    --通過merger的方式,將B表的column3字段更新到A表的column2列中
    merge into t1 Using (select * from t1 ) on (t1.A = t2.A)
    when matched then update set t1.B = t2.C

通過這種方式介返,在測(cè)試環(huán)境實(shí)際跑下來十分鐘左右可以更新完成拴事。
merge into的詳細(xì)用法可以參考這篇文章:
Oracle中merge into的使用

使用CTAS

create table as 的方式在之前的使用中,多用于創(chuàng)建備份表圣蝎。因?yàn)檫@次需求才認(rèn)識(shí)到其更多的用法刃宵。性能十分強(qiáng)悍。

    --首先使用ctas的方式創(chuàng)建臨時(shí)表
    create table temp_A as select t1.*,t2.C from t1 left join t2 on t1.A = t2.A;
    --刪除原始表
    drop table A;
    --將臨時(shí)表重名稱
     rename temp_A to A;
    --重新創(chuàng)建原表的索引等徘公。牲证。。
    create index ......

測(cè)試環(huán)境執(zhí)行下來关面,一分鐘左右可以執(zhí)行完成坦袍。
CTAS的更多用法,可以參考Oracle官網(wǎng)的如下內(nèi)容:
How to Update millions or records in a table
這一段內(nèi)容信息量非常大等太,值得仔細(xì)品讀捂齐。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市缩抡,隨后出現(xiàn)的幾起案子奠宜,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件挎塌,死亡現(xiàn)場(chǎng)離奇詭異徘六,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)榴都,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門待锈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人嘴高,你說我怎么就攤上這事竿音。” “怎么了拴驮?”我有些...
    開封第一講書人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵春瞬,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我套啤,道長(zhǎng)宽气,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任潜沦,我火速辦了婚禮萄涯,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘唆鸡。我一直安慰自己涝影,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開白布争占。 她就那樣靜靜地躺著燃逻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪臂痕。 梳的紋絲不亂的頭發(fā)上伯襟,一...
    開封第一講書人閱讀 51,292評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音刻蟹,去河邊找鬼逗旁。 笑死,一個(gè)胖子當(dāng)著我的面吹牛舆瘪,可吹牛的內(nèi)容都是我干的片效。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼英古,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼淀衣!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起召调,我...
    開封第一講書人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤膨桥,失蹤者是張志新(化名)和其女友劉穎蛮浑,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體只嚣,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沮稚,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了册舞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蕴掏。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖调鲸,靈堂內(nèi)的尸體忽然破棺而出盛杰,到底是詐尸還是另有隱情,我是刑警寧澤藐石,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布即供,位于F島的核電站,受9級(jí)特大地震影響于微,放射性物質(zhì)發(fā)生泄漏逗嫡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一角雷、第九天 我趴在偏房一處隱蔽的房頂上張望祸穷。 院中可真熱鬧,春花似錦勺三、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至呆万,卻和暖如春商源,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谋减。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工牡彻, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人出爹。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓庄吼,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親严就。 傳聞我的和親對(duì)象是個(gè)殘疾皇子总寻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容