校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > postgresql 刪除重復數據的幾種方法小結

postgresql 刪除重復數據的幾種方法小結

熱門標簽:智能電銷機器人教育 高德地圖標注電話怎么沒了 北京智能外呼系統供應商家 中國地圖標注省份用什么符號 無錫梁溪公司怎樣申請400電話 孝感銷售電銷機器人廠家 電話機器人錄音師薪資 江西穩定外呼系統供應商 奧維地圖標注字體大小修改

在使用PG數據庫的這段時間,總結了三種刪除重復數據的方法,其中最容易想到的就是最常規的刪除方法,但此方法性能較差,刪數據耗時較久,雖容易實現,但性能太差,影響寫數據的速率。

另外就是被使用的group by刪除方法,效率較高。

還有一種是剛發現的,還沒有驗證,現在就總結下這三種刪除方法,并驗證各自的執行效率。

首先創建一張基礎表,并插入一定量的重復數據。

  test=# create table deltest(id int, name varchar(255));
  CREATE TABLE
  test=# create table deltest_bk (like deltest);
  CREATE TABLE
  test=# insert into deltest select generate_series(1, 10000), 'ZhangSan';
  INSERT 0 10000
  test=# insert into deltest select generate_series(1, 10000), 'ZhangSan';
  INSERT 0 10000
  test=# insert into deltest_bk select * from deltest;

常規刪除方法

最容易想到的方法就是判斷數據是否重復,對于重復的數據只保留ctid最小(或最大)的那條數據,刪除其他的數據。

test=# explain analyse delete from deltest a where a.ctid > (select min(t.ctid) from deltest t where a.id=t.id);
                               QUERY PLAN
  -----------------------------------------------------------------------------------------------------------------------------
  Delete on deltest a (cost=0.00..195616.30 rows=1518 width=6) (actual time=67758.866..67758.866 rows=0 loops=1)
    -> Seq Scan on deltest a (cost=0.00..195616.30 rows=1518 width=6) (actual time=32896.517..67663.228 rows=10000 loops=1)
     Filter: (ctid > (SubPlan 1))
     Rows Removed by Filter: 10000
     SubPlan 1
      -> Aggregate (cost=128.10..128.10 rows=1 width=6) (actual time=3.374..3.374 rows=1 loops=20000)
         -> Seq Scan on deltest t (cost=0.00..128.07 rows=8 width=6) (actual time=0.831..3.344 rows=2 loops=20000)
            Filter: (a.id = id)
            Rows Removed by Filter: 19998
  Total runtime: 67758.931 ms
  test=# select count(*) from deltest;
  count
  -------
  10000
  (1 行記錄)

可以看到,id相同的數據,保留ctid最小的那條,其他的刪除。相當于把deltest表中的數據刪掉一半,耗時達到67s多。相當慢。

group by刪除方法

第二種方法為group by方法,通過分組找到ctid最小的數據,然后刪除其他數據。

  test=# truncate table deltest;
  TRUNCATE TABLE
  test=# insert into deltest select * from deltest_bk;
  INSERT 0 20000
  test=# explain analyse delete from deltest a where a.ctid not in (select min(ctid) from deltest group by id);
                               QUERY PLAN
  ----------------------------------------------------------------------------------------------------------------------------------
  Delete on deltest a (cost=131.89..2930.46 rows=763 width=6) (actual time=30942.496..30942.496 rows=0 loops=1)
    -> Seq Scan on deltest a (cost=131.89..2930.46 rows=763 width=6) (actual time=10186.296..30814.366 rows=10000 loops=1)
     Filter: (NOT (SubPlan 1))
     Rows Removed by Filter: 10000
     SubPlan 1
      -> Materialize (cost=131.89..134.89 rows=200 width=10) (actual time=0.001..0.471 rows=7500 loops=20000)
         -> HashAggregate (cost=131.89..133.89 rows=200 width=10) (actual time=10.568..13.584 rows=10000 loops=1)
            -> Seq Scan on deltest (cost=0.00..124.26 rows=1526 width=10) (actual time=0.006..3.829 rows=20000 loops=1)
   Total runtime: 30942.819 ms
  (9 行記錄)
  test=# select count(*) from deltest;
   count
  -------
  10000
  (1 行記錄)

可以看到同樣是刪除一半的數據,使用group by的方式,時間節省了一半。但仍含需要30s,下面試一下第三種刪除操作。

新的刪除方法

在postgres修煉之道這本書中,作者提到一種效率較高的刪除方法, 在這里驗證一下,具體如下:

  test=# truncate table deltest;
  TRUNCATE TABLE
  test=# insert into deltest select * from deltest_bk;
  INSERT 0 20000                             
  test=# explain analyze delete from deltest a where a.ctid = any(array (select ctid from (select row_number() over (partition by id), ctid from deltest) t where t.row_number > 1));
                               QUERY PLAN
  ----------------------------------------------------------------------------------------------------------------------------------
  Delete on deltest a (cost=250.74..270.84 rows=10 width=6) (actual time=98.363..98.363 rows=0 loops=1)
  InitPlan 1 (returns $0)
   -> Subquery Scan on t (cost=204.95..250.73 rows=509 width=6) (actual time=29.446..47.867 rows=10000 loops=1)
      Filter: (t.row_number > 1)
      Rows Removed by Filter: 10000
      -> WindowAgg (cost=204.95..231.66 rows=1526 width=10) (actual time=29.436..44.790 rows=20000 loops=1)
         -> Sort (cost=204.95..208.77 rows=1526 width=10) (actual time=12.466..13.754 rows=20000 loops=1)
            Sort Key: deltest.id
            Sort Method: quicksort Memory: 1294kB
            -> Seq Scan on deltest (cost=0.00..124.26 rows=1526 width=10) (actual time=0.021..5.110 rows=20000 loops=1)
  -> Tid Scan on deltest a (cost=0.01..20.11 rows=10 width=6) (actual time=82.983..88.751 rows=10000 loops=1)
     TID Cond: (ctid = ANY ($0))
  Total runtime: 98.912 ms
  (13 行記錄)
  test=# select count(*) from deltest;
  count
  -------
  10000
  (1 行記錄)

看到上述結果,真讓我吃驚了一把,這么快的刪除方法還是首次看到,自己真實孤陋寡聞,在這里要膜拜一下修煉之道這本書的大神作者了。

補充:pgsql 刪除表中重復數據保留其中的一條

1.在表中(表名:table 主鍵:id)增加一個字段rownum,類型為serial

2.執行語句:

delete from table where rownum not in( 
select max(rownum) from table group by id 
)

3.最后刪除rownum

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL 刪除check約束的實現
  • postgresql刪除主鍵的操作
  • PostgreSQL 實現快速刪除一個用戶
  • postgresql 實現多表關聯刪除
  • Postgresql創建新增、刪除與修改觸發器的方法
  • PostgreSQL刪除更新優化操作
  • mybatis postgresql 批量刪除操作方法
  • postgresql 刪除重復數據案例詳解

標簽:泰州 海北 通化 那曲 臨滄 阜陽 齊齊哈爾 荊州

巨人網絡通訊聲明:本文標題《postgresql 刪除重復數據的幾種方法小結》,本文關鍵詞  postgresql,刪除,重復,數據,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《postgresql 刪除重復數據的幾種方法小結》相關的同類信息!
  • 本頁收集關于postgresql 刪除重復數據的幾種方法小結的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲欧美国产毛片在线| av在线不卡电影| 久久精品这里都是精品| 久久99精品久久久久久动态图| 欧美老肥妇做.爰bbww视频| 亚洲日本在线天堂| 91精品国产综合久久久久| 99r精品视频| 国产一区二区三区在线观看免费| 亚洲女人****多毛耸耸8| 26uuu色噜噜精品一区二区| 欧美图区在线视频| 欧美视频一区在线观看| 美女网站色91| 99视频一区二区| 性感美女极品91精品| 欧美日韩久久久久久| 成人免费在线视频观看| 成人激情图片网| 亚洲天堂网中文字| 国产视频一区在线播放| 日韩精品一区二区三区视频播放| 欧美电影免费观看高清完整版在线观看 | 99精品国产热久久91蜜凸| 久久综合九色综合97婷婷女人| 精品一区二区三区在线播放 | 久久99精品一区二区三区三区| 亚洲国产高清aⅴ视频| 26uuu国产日韩综合| 欧美乱妇20p| 欧美性视频一区二区三区| 91在线看国产| 91网站最新地址| www.日韩大片| www.亚洲国产| 91美女片黄在线| www.亚洲色图.com| 91免费观看国产| 色一情一乱一乱一91av| 一本色道综合亚洲| 91黄色激情网站| 欧美做爰猛烈大尺度电影无法无天| 92精品国产成人观看免费| 91亚洲精华国产精华精华液| bt7086福利一区国产| 高清beeg欧美| 91偷拍与自偷拍精品| 一本到高清视频免费精品| 成人av在线看| 欧洲一区二区av| 欧美日韩精品一二三区| 日韩久久精品一区| 国产欧美一区二区三区网站| 国产欧美一区二区精品仙草咪 | 国产精品久久久久9999吃药| 国产精品进线69影院| 一区二区免费在线| 美女一区二区三区在线观看| 韩国三级电影一区二区| 不卡一区在线观看| 欧美性猛交xxxx黑人交| 欧美一区二区免费观在线| 26uuu国产在线精品一区二区| 欧美极品xxx| 亚洲一区二区黄色| 精品一区二区日韩| gogo大胆日本视频一区| 欧美日韩一区不卡| 久久久久久夜精品精品免费| 亚洲欧洲99久久| 亚洲成人手机在线| 国产成人无遮挡在线视频| 91蝌蚪porny| 日韩欧美一二区| 亚洲色图在线视频| 日本视频在线一区| 99精品欧美一区二区三区小说| 欧美日韩一二三区| 亚洲国产精品99久久久久久久久| 亚洲一区二区三区四区的| 国产一区视频网站| 欧美亚洲丝袜传媒另类| 久久综合中文字幕| 亚洲国产乱码最新视频| 国产高清精品网站| 久久你懂得1024| 亚洲精品ww久久久久久p站| 免费看欧美女人艹b| 91亚洲精品久久久蜜桃网站| 欧美一区二区三区电影| 亚洲欧美日韩久久| 国产麻豆欧美日韩一区| 欧美老年两性高潮| 亚洲欧美日韩人成在线播放| 麻豆成人免费电影| 色狠狠桃花综合| 国产日产欧产精品推荐色| 日韩国产欧美在线视频| 一本到不卡免费一区二区| 久久久亚洲午夜电影| 午夜成人免费视频| 色呦呦网站一区| 国产精品理伦片| 国内精品国产三级国产a久久| 欧美性大战久久| 综合电影一区二区三区 | 国产一区二区三区四区五区入口 | 日本欧美在线观看| 色偷偷久久人人79超碰人人澡| 久久久亚洲高清| 青青国产91久久久久久 | 欧美mv日韩mv国产网站| 日韩中文字幕不卡| 欧美午夜影院一区| 亚洲乱码日产精品bd| 成人午夜私人影院| 国产三级欧美三级| 精品一区二区免费视频| 欧美一区二区三区视频在线 | 日韩欧美一级二级三级| 亚洲3atv精品一区二区三区| 不卡高清视频专区| 国产精品福利av| 成人精品国产一区二区4080 | 亚洲精品成人精品456| 国产大片一区二区| 久久久电影一区二区三区| 日韩av电影免费观看高清完整版| 在线观看成人免费视频| 一区二区在线观看视频在线观看| av一区二区久久| 一区二区中文字幕在线| av欧美精品.com| 亚洲视频在线一区二区| 国产高清精品久久久久| 激情小说欧美图片| 久久婷婷国产综合国色天香 | 91麻豆精品久久久久蜜臀 | 亚洲卡通欧美制服中文| 天天色综合成人网| 91香蕉视频黄| 91蜜桃网址入口| 粉嫩一区二区三区在线看| 国产精品一二二区| 中文字幕一区二| 91精品久久久久久久久99蜜臂| 欧美精品乱人伦久久久久久| 日韩亚洲电影在线| 亚洲精品一区二区三区福利| av在线一区二区三区| 久久99久久精品欧美| 青娱乐精品视频| 日韩毛片一二三区| 欧美精品一区二区精品网| 在线亚洲免费视频| 不卡一区二区三区四区| 国产乱码精品一区二区三| 五月婷婷久久综合| 国产精品青草久久| 欧美国产成人精品| 国产精品第五页| 麻豆精品一区二区三区| 亚洲h动漫在线| 亚洲成av人**亚洲成av**| 日韩精品视频网站| 亚洲线精品一区二区三区| 久久久精品人体av艺术| 国产夜色精品一区二区av| 最新日韩av在线| 国产精品亲子乱子伦xxxx裸| 欧美精品在线视频| 精品免费99久久| 国产精品乱人伦| 一区二区激情小说| 日本在线播放一区二区三区| 丁香婷婷综合激情五月色| 99精品视频在线免费观看| 成人综合在线观看| 91色综合久久久久婷婷| 色综合天天做天天爱| 91丨porny丨首页| 91精品福利在线一区二区三区| 欧美肥妇bbw| 国产婷婷色一区二区三区| 国产精品蜜臀av| 一区在线观看视频| 亚洲一区二区3| 成人动漫一区二区| 亚洲乱码中文字幕综合| 国产呦萝稀缺另类资源| 在线观看日韩毛片| 精品日产卡一卡二卡麻豆| 欧美日韩高清一区二区不卡| 国产精品美女www爽爽爽| 肉丝袜脚交视频一区二区| 成+人+亚洲+综合天堂| 欧美成人精精品一区二区频| 污片在线观看一区二区| 成人国产亚洲欧美成人综合网 | 99久久精品久久久久久清纯|