亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 2214 | 回復(fù): 6
打印 上一主題 下一主題

請教個簡單問題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2010-12-30 14:14 |只看該作者 |倒序瀏覽
SQL就是個:update A SET A.COL1 = (SELECT B.COL1 FROM B WHERE A.ID=B.ID) WHERE EXISTS(SELECT 1 FROM B WHERE A.ID=B.ID)

A,B表中id都是唯一索引
A中的數(shù)據(jù)有20w條件,B中的數(shù)據(jù)10條左右

但是更新的時候,數(shù)據(jù)庫只利用了B的索引,無法利用A的索引
怎么寫才能利用上A的索引

論壇徽章:
0
2 [報告]
發(fā)表于 2010-12-30 14:20 |只看該作者
如果b.id是PK或unique的話,可以這樣:
update
(select a.col1 ac, b.col1 bc
   from a, b
where a.id = b.id)
set ac = bc;

論壇徽章:
0
3 [報告]
發(fā)表于 2010-12-30 14:23 |只看該作者
非常感謝,我試一下

論壇徽章:
0
4 [報告]
發(fā)表于 2010-12-30 14:41 |只看該作者
能說一下以前的寫法哪里不合適嗎,因為程序里用到oracle數(shù)據(jù)庫update更新的地方都這么寫的,不知道具體什么原因造成利用不上A表索引,改變寫法影響很大

論壇徽章:
0
5 [報告]
發(fā)表于 2010-12-30 14:52 |只看該作者
本帖最后由 doni 于 2010-12-30 14:55 編輯

首先,update ... where exists 這樣是不會用索引的
其次,A表不走索引基本上也沒什么問題,因為這個update可能會命中大部row,所以沒有必要用索引
如果,A表中會被update的row很少的話,就要考慮用我前面給出的SQL

論壇徽章:
0
6 [報告]
發(fā)表于 2010-12-30 15:29 |只看該作者
非常感謝耐心解答

論壇徽章:
59
2015七夕節(jié)徽章
日期:2015-08-24 11:17:25ChinaUnix專家徽章
日期:2015-07-20 09:19:30每周論壇發(fā)貼之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38榮譽版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年紀(jì)念徽章
日期:2015-07-20 11:05:27IT運維版塊每日發(fā)帖之星
日期:2015-07-20 11:05:34操作系統(tǒng)版塊每日發(fā)帖之星
日期:2015-07-20 11:05:36程序設(shè)計版塊每日發(fā)帖之星
日期:2015-07-20 11:05:40數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-07-20 11:05:432015年辭舊歲徽章
日期:2015-07-20 11:05:44
7 [報告]
發(fā)表于 2010-12-30 23:09 |只看該作者
好復(fù)雜啊。呵呵。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP