亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

oracle快速刪除重復的記錄

2024-08-29 13:57:33
字體:
來源:轉載
供稿:網友
正在看的ORACLE教程是:oracle快速刪除重復的記錄。做項目的時候,一位同事導數據的時候,不小心把一個表中的數據全都搞重了,也就是說,這個表里所有的記錄都有一條重復的。這個表的數據是千萬級的,而且是生產系統。也就是說,不能把所有的記錄都刪除,而且必須快速的把重復記錄刪掉。

對此,總結了一下刪除重復記錄的方法,以及每種方法的優缺點。

為了陳訴方便,假設表名為Tbl,表中有三列col1,col2,col3,其中col1,col2是主鍵,并且,col1,col2上加了索引。

1、通過創建臨時表

可以把數據先導入到一個臨時表中,然后刪除原表的數據,再把數據導回原表,SQL語句如下:

creat table tbl_tmp (select distinct* from tbl);truncate table tbl;//清空表記錄insert into tbl select * from tbl_tmp;//將臨時表中的數據插回來。 
這種方法可以實現需求,但是很明顯,對于一個千萬級記錄的表,這種方法很慢,在生產系統中,這會給系統帶來很大的開銷,不可行。

2、利用rowid

在oracle中,每一條記錄都有一個rowid,rowid在整個數據庫中是唯一的,rowid確定了每條記錄是oracle中的哪一個數據文件、塊、行上。在重復的記錄中,可能所有列的內容都相同,但rowid不會相同。SQL語句如下:

delete from tbl where rowid in (select a.rowid from tbl a, tbl b where a.rowid>b.rowid and a.col1=b.col1 and a.col2 = b.col2) 
如果已經知道每條記錄只有一條重復的,這個sql語句適用。但是如果每條記錄的重復記錄有N條,這個N是未知的,就要考慮適用下面這種方法了。

3、利用max或min函數

這里也要使用rowid,與上面不同的是結合max或min函數來實現。SQL語句如下

delete from tbl awhere rowid not in (select max(b.rowid) from tbl b where a.col1=b.col1 and a.col2 = b.col2);//這里max使用min也可以 
或者用下面的語句

delete from tbl awhere rowid<(select max(b.rowid) from tbl b where a.col1=b.col1 and a.col2 = b.col2);//這里如果把max換成min的話,前面的where子句中需要把"<"改為">" 
跟上面的方法思路基本是一樣的,不過使用了group by,減少了顯性的比較條件,提高效率。SQL語句如下:

deletefrom tbl where rowid not in (select max(rowid) from tbl tgroup by t.col1, t.col2);delete from tbl where (col1, col2) in (select col1,col2 from tblgroup bycol1,col2havingcount(*) >1)and rowidnotin(selectnin(rowid)fromtblgroup bycol1,col2havingcount(*) >1) 
還有一種方法,對于表中有重復記錄的記錄比較少的,并且有索引的情況,比較適用。假定col1,col2上有索引,并且tbl表中有重復記錄的記錄比較少,SQL語句如下4、利用group by,提高效率 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久中文久久字幕| 成人精品一区二区三区电影黑人| 午夜精品久久久久久久99热| 久久精品成人动漫| 午夜精品一区二区三区在线播放| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲午夜精品久久久久久久久久久久| 欧美一级高清免费播放| 久久99国产综合精品女同| 亚洲视频在线视频| 国产精品视频内| 美女精品久久久| 亚洲成人在线网| 精品久久久久久| 在线播放国产一区中文字幕剧情欧美| 国产99久久精品一区二区永久免费| 成人a免费视频| 欧美人与性动交a欧美精品| 欧美又大粗又爽又黄大片视频| 一级做a爰片久久毛片美女图片| 成人淫片在线看| 国产精品www色诱视频| 欧美日韩中文字幕在线视频| 日韩av电影手机在线观看| 91九色在线视频| 欧美激情一区二区三区在线视频观看| 国产精品久久中文| 亚洲国产精品成人va在线观看| 国产精品九九九| 国产亚洲视频在线观看| 国产精品www| 国内精品400部情侣激情| 久久人人爽人人爽爽久久| 日本久久久久久久| 欧美性xxxx极品高清hd直播| 久久久国产视频91| 亚洲精品美女久久久久| 亚洲激情中文字幕| www.亚洲一区| 亚洲欧洲一区二区三区在线观看| 在线播放国产精品| 国产一区二区三区18| 国产精品女人久久久久久| 日日骚久久av| 国产97在线亚洲| 亚洲激情在线观看视频免费| 中文字幕亚洲专区| 精品免费在线视频| 欧美网站在线观看| 91香蕉电影院| 亚洲影院高清在线| 91chinesevideo永久地址| 久久精品成人欧美大片古装| 国产不卡在线观看| 日韩精品视频三区| 日韩高清中文字幕| 亚洲成人三级在线| 欧美在线观看一区二区三区| 精品久久久久久国产| 国产综合久久久久| 日韩av成人在线| 欧美日韩成人网| 国产精品丝袜一区二区三区| 久久久亚洲精品视频| 91麻豆国产精品| 亚洲福利在线看| 国产欧美日韩中文字幕在线| 亚洲男人天堂九九视频| 中文字幕在线看视频国产欧美| 98精品国产自产在线观看| 亚洲精品99久久久久中文字幕| 欧美一级视频在线观看| 久久亚洲国产精品成人av秋霞| 红桃av永久久久| 97久久久免费福利网址| 成人欧美一区二区三区黑人孕妇| 亚洲欧美中文字幕| 日韩在线观看成人| 久久夜精品香蕉| 最近2019好看的中文字幕免费| 日韩欧美精品在线观看| 国产成人av在线| 国产日韩在线观看av| 国内精品美女av在线播放| 欧美激情videos| 久久夜色精品国产| 91视频-88av| 亚洲片国产一区一级在线观看| 亚洲美女av网站| 久久天天躁狠狠躁夜夜躁2014| 亚洲美女免费精品视频在线观看| 456国产精品| 欧美亚洲成人精品| 91精品国产91久久久久久不卡| 亚洲欧洲国产伦综合| 中文字幕亚洲欧美日韩高清| 91精品国产高清久久久久久久久| 91欧美激情另类亚洲| 日韩美女视频在线观看| 亚洲精品一区久久久久久| 亚洲天堂av在线免费观看| 91免费看片在线| 欧美做受高潮电影o| 国产拍精品一二三| 国产日韩欧美夫妻视频在线观看| 亚洲精品久久久久| 日韩成人中文字幕| 国内成人精品视频| 日韩第一页在线| 日韩欧美国产成人| 久久精品中文字幕| 国产精品久久久久久婷婷天堂| 成人免费视频a| 国产精品aaaa| 精品亚洲夜色av98在线观看| 日韩中文av在线| 日韩电影免费观看在线| 欧美激情第一页xxx| 成人在线视频网站| 亚洲综合在线做性| 另类专区欧美制服同性| 国产精品爽爽ⅴa在线观看| 最近中文字幕日韩精品| 国产欧美日韩中文字幕| 欧美午夜美女看片| 国产精品色婷婷视频| 欧美激情精品久久久久久黑人| 久久精品国产2020观看福利| 91在线免费视频| 97视频在线观看成人| 青青久久av北条麻妃黑人| 亚洲аv电影天堂网| 米奇精品一区二区三区在线观看| 色yeye香蕉凹凸一区二区av| 欧洲日本亚洲国产区| 国产不卡av在线| 欧美日韩在线视频观看| 日韩大陆毛片av| 97精品久久久中文字幕免费| 亚洲精品久久久久久下一站| 国产精品主播视频| 成人免费淫片视频软件| 国产成人激情小视频| 久久亚洲精品网站| 欧美大片在线免费观看| 亚洲国产成人精品电影| 97国产精品视频| 亚洲欧美日韩久久久久久| 欧美精品videosex性欧美| 国产精品日韩在线播放| 日韩精品有码在线观看| 亚洲老头同性xxxxx| 欧美极品少妇与黑人| 中日韩美女免费视频网址在线观看| 日韩精品中文在线观看| 国产精品成人aaaaa网站| 国产精品久久久久99| 亚洲精品wwwww| 国产精品国语对白| 91久久国产婷婷一区二区| 成人黄色av免费在线观看| 日韩免费在线看| 91精品国产自产在线老师啪| 欧美在线亚洲在线|