WEB开发网      濠电娀娼ч崐濠氬疾椤愶附鍋熸い鏍ㄧ〒闂勫嫰鏌﹀Ο渚Ц闁诲氦顕ч湁婵犲﹤楠告禍鍓х磼鏉堛劌绗氶柟宄版嚇閹晠宕归銈嗘濠电偞鍨堕幐鎾磻閹捐秮褰掓偐閻戞﹩妫勯梺鎼炲妼鐎涒晝绮嬪澶樻晝闁挎繂鏌婇敃鍌涚厵閻庢稒锚閻忥絾绻濇繝鍐ㄧ伌闁诡垰鍟村畷鐔碱敂閸♀晙绱樺┑鐐差嚟婵儳螞閸曨剚鍙忛柍鍝勬噹缁€澶嬬箾閹存繄锛嶆鐐灲閹綊宕惰濡插鏌涢妸銉ヮ劉缂佸倸绉归弫鎾绘晸閿燂拷 ---闂備焦瀵уú鈺呭箯閿燂拷
开发学院数据库Oracle 优化一条UPDATE语句 阅读

优化一条UPDATE语句

 2008-08-27 12:43:43 来源:WEB开发网 闂備線娼уΛ鎾箯閿燂拷闂備礁鎲¢崹鐢垫崲閹扮増鍎嶆い鎺戝€甸崑鎾斥槈濞嗗秳娌紓鍌氱▌閹凤拷濠电姭鎷冮崨顓濈捕闂侀潧娲ゅú銊╁焵椤掍胶鈯曢柕鍥╁仧缁辩偤鏁撻敓锟�闂備線娼уΛ鎾箯閿燂拷  闂備胶枪缁绘鈻嶉弴銏犳瀬闁绘劕鎼痪褔鏌曟繝蹇曠窗闁煎壊浜滈—鍐偓锝庡墮娴犙勭箾閸喎鐏ユい鏇樺劦椤㈡瑩鎮℃惔銇帮拷
核心提示:最近见到一条开发人员写的UPDATE语句, 觉得没什么不对, 可又觉得有地方不对, 因为性能低下, UPDATEASET(COL2,COL3)=(SELECTCOL1,'T'FROMBWHEREB.COL1=A.COL1)WHEREEXISTS(SELECTB.COL1FROMBWHEREB.COL1=

最近见到一条开发人员写的UPDATE语句, 觉得没什么不对, 可又觉得有地方不对, 因为性能低下。

  UPDATEASET
(COL2,COL3)=(SELECTCOL1,'T'
FROMBWHEREB.COL1=A.COL1)
WHEREEXISTS
(SELECTB.COL1FROMBWHEREB.COL1=A.COL1)

也就更新几十万条记录, 没这么慢的啊. 最后发现这个SQL语句可以简化为如下.

  UPDATEASETCOL2=COL1,COL3='T'
WHEREEXISTS
(SELECTB.COL1FROMBWHEREB.COL1=A.COL1)

说明还有很多可以提高的地方。

Tags:优化 UPDATE 语句

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接