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

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
12下一頁
最近訪問板塊 發(fā)新帖
查看: 10316 | 回復(fù): 14
打印 上一主題 下一主題

mysql關(guān)聯(lián)刪除記錄問題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2009-05-14 00:18 |只看該作者 |倒序?yàn)g覽
有倆個(gè)表table1 , table2

talbe1   有倆個(gè)字段id,pid     有2千萬條記錄         同一pid對(duì)應(yīng)多個(gè)id
table2   有一個(gè)字段pid         有100萬條記錄        pid唯一

想要?jiǎng)h除表table1中記錄,條件是table1.pid=table2.pid

大家給推薦一個(gè)效率高一點(diǎn)的方法,用delete表關(guān)聯(lián)刪除效率不是很高,感覺有點(diǎn)慢

[ 本帖最后由 steel_lei 于 2009-5-14 00:23 編輯 ]

論壇徽章:
0
2 [報(bào)告]
發(fā)表于 2009-05-14 09:29 |只看該作者
我想到的是select建新表,但是好像也快不了多少

CREATE TABLE tmp AS  SELECT  * FROM table1  WHERE pid NOT IN (SELECT pid FROM table2)

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2009-05-14 09:43 |只看該作者
原帖由 ws00377531 于 2009-5-14 09:29 發(fā)表
我想到的是select建新表,但是好像也快不了多少

CREATE TABLE tmp AS  SELECT  * FROM table1  WHERE pid NOT IN (SELECT pid FROM table2)


我在測(cè)試創(chuàng)建表,看一下create的效率,但后面沒用not in,用not in會(huì)很慢的,用表關(guān)聯(lián)會(huì)好很多

論壇徽章:
1
白銀圣斗士
日期:2015-11-23 08:33:04
4 [報(bào)告]
發(fā)表于 2009-05-14 09:52 |只看該作者
not in 更慢的了,關(guān)連要快?此饕恕

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2009-05-14 09:55 |只看該作者
改用left join吧
SELECT  * FROM table1 a left join table2 b on (a.pid=b.pid) where b.pid is null

論壇徽章:
1
白銀圣斗士
日期:2015-11-23 08:33:04
6 [報(bào)告]
發(fā)表于 2009-05-14 10:14 |只看該作者
原帖由 voxxu 于 2009-5-14 09:55 發(fā)表
改用left join吧
SELECT  * FROM table1 a left join table2 b on (a.pid=b.pid) where b.pid is null

這個(gè)好。

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2009-05-14 10:16 |只看該作者
對(duì)于一個(gè)2000W的大表,一次走一個(gè)全表掃描確是很困難的。不過對(duì)于100W的表走一個(gè)全描掃也困難。

如果做這件事情又不想影響太大,就要分步來完成。

我給你一個(gè)思路你來參考一下。
首先衡量刪除操作有多大。
selet count(*) from table1 a ,table2 b where a.pid=b.pid;
如果都有索引的話,這個(gè)操作還是挺快的。
如果操作的操作大于原表的40%,那么很有必要重建這個(gè)表了。

重建表的方法:就是按條件提取數(shù)據(jù)到一個(gè)新表,最后改名完成。這是一種方案。

另一種 刪除方向。

上面通過比較覺的需要?jiǎng)h除的量不是太大時(shí),把需要?jiǎng)h除的PID生到到另一個(gè)臨時(shí)表中。
mysql DBname -e "select a.pid from table1 a ,table2 b where a.pid=b.pid">del_pid.txt;

sed -i '1d' del_pid.txt
awk '{print "delete from table1 where pid=",$1,";"}' del_pid.txt >del_pid.sql
mysql DBname<del_pid.sql

這樣把SQL拆成多個(gè)SQL執(zhí)行速度應(yīng)該不會(huì)太慢了。

如果還是感覺不行,那就只能分段操作了。

論壇徽章:
1
白銀圣斗士
日期:2015-11-23 08:33:04
8 [報(bào)告]
發(fā)表于 2009-05-14 10:30 |只看該作者

回復(fù) #7 Coolriver 的帖子

這個(gè)很好,我們經(jīng)常也這樣做,用perl..

不過一般我是數(shù)據(jù)庫做的事情讓數(shù)據(jù)庫做。

論壇徽章:
0
9 [報(bào)告]
發(fā)表于 2009-05-14 17:04 |只看該作者
原帖由 楓影誰用了 于 2009-5-14 10:30 發(fā)表
這個(gè)很好,我們經(jīng)常也這樣做,用perl..

不過一般我是數(shù)據(jù)庫做的事情讓數(shù)據(jù)庫做。

我現(xiàn)在很多工作拿到數(shù)據(jù)外面做了。
數(shù)據(jù)量大了,全壓到DB上,都出不了結(jié)果了。:)

論壇徽章:
9
每日論壇發(fā)貼之星
日期:2016-01-04 06:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-01-04 06:20:00每日論壇發(fā)貼之星
日期:2016-01-04 06:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-01-04 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-01-04 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-01-04 06:20:00綜合交流區(qū)版塊每日發(fā)帖之星
日期:2016-01-04 06:20:00綜合交流區(qū)版塊每日發(fā)帖之星
日期:2016-01-04 06:20:00數(shù)據(jù)庫技術(shù)版塊每周發(fā)帖之星
日期:2016-03-07 16:30:25
10 [報(bào)告]
發(fā)表于 2009-05-14 17:55 |只看該作者
原帖由 Coolriver 于 2009-5-14 10:16 發(fā)表
對(duì)于一個(gè)2000W的大表,一次走一個(gè)全表掃描確是很困難的。不過對(duì)于100W的表走一個(gè)全描掃也困難。

如果做這件事情又不想影響太大,就要分步來完成。

我給你一個(gè)思路你來參考一下。
首先衡量刪除操作有多大 ...


很不錯(cuò)~收藏了~但是把id放到臨時(shí)文件里會(huì)有效率問題嗎?跟建個(gè)臨時(shí)表存id,哪個(gè)好一點(diǎn)?
您需要登錄后才可以回帖 登錄 | 注冊(cè)

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

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP