PostgreSQL刪除表中重複資料
一、測試資料建立
postgres=# create table test_chongfu(id int not null default null,name char(50) default null,class int default null); CREATE TABLE postgres=# insert into test_chongfu values(1,'AA',1); INSERT 0 1 postgres=# insert into test_chongfu values(2,'AB',8); INSERT 0 1 postgres=# insert into test_chongfu values(3,'AB',8); INSERT 0 1 postgres=# insert into test_chongfu values(4,'BB',5); INSERT 0 1 postgres=# insert into test_chongfu values(5,'BD',7); INSERT 0 1 postgres=# insert into test_chongfu values(6,'BD',7); INSERT 0 1 postgres=# select * from test_chongfu; id | name | class ----+----------------------------------------------------+------- 1 | AA | 1 2 | AB | 8 3 | AB | 8 4 | BB | 5 5 | BD | 7 6 | BD | 7 (6 rows) postgres=# alter table test_chongfu add constraint pk1 primary key ("id"); ALTER TABLE postgres=# \d test_chongfu Table "public.test_chongfu" Column | Type | Collation | Nullable | Default --------+---------------+-----------+----------+-------------- id | integer | | not null | name | character(50) | | | NULL::bpchar class | integer | | | Indexes: "pk1" PRIMARY KEY, btree (id)
二、存在唯一標識情況
如果刪除重複資料的表裡有除ctid外的唯一標識,可以利用這一列,我這裡為id列。
postgres=# select * from test_chongfu; id | name | class ----+----------------------------------------------------+------- 1 | AA | 1 2 | AB | 8 3 | AB | 8 4 | BB | 5 5 | BD | 7 6 | BD | 7 (6 rows) postgres=# select * from test_chongfu where id not in (select min(id) from test_chongfu group by name,class); id | name | class ----+----------------------------------------------------+------- 3 | AB | 8 6 | BD | 7 (2 rows)
透過id列,檢視根據name和class兩列匹配的重複列。執行如下語句刪除重複資料。
postgres=# delete from test_chongfu where id not in (select min(id) from test_chongfu group by name,class); DELETE 2 postgres=# select * from test_chongfu; id | name | class ----+----------------------------------------------------+------- 1 | AA | 1 2 | AB | 8 4 | BB | 5 5 | BD | 7 (4 rows)
三、不存在唯一標識情況
恢復初始測試環境。如果表裡不存在唯一標識列,可以透過ctid來進行。ctid類似於oracle的rowid,但是形式不同。
postgres=# select * from test_chongfu; id | name | class ----+----------------------------------------------------+------- 1 | AA | 1 2 | AB | 8 3 | AB | 8 4 | BB | 5 5 | BD | 7 6 | BD | 7 (6 rows) postgres=# select * from test_chongfu where ctid not in( select min(ctid) from test_chongfu group by name,class); id | name | class ----+----------------------------------------------------+------- 3 | AB | 8 6 | BD | 7 (2 rows) postgres=# delete from test_chongfu where ctid not in( select min(ctid) from test_chongfu group by name,class); DELETE 2 postgres=# select * from test_chongfu; id | name | class ----+----------------------------------------------------+------- 1 | AA | 1 2 | AB | 8 4 | BB | 5 5 | BD | 7 (4 rows)
四、not in最佳化
in本來效率就很低,not in的效率更加低,如果資料量很大的情況,可能執行時間會特別長。因此可以嘗試把查詢到的唯一資料重新插入到一張新表裡,然後把原來舊錶刪掉,最後修改去重資料後的新表名為舊錶名。
postgres=# create table tab_new as select * from test_chongfu where ctid in(select min(ctid) from test_chongfu group by name,class); SELECT 4 postgres=# select * from tab_new; id | name | class ----+----------------------------------------------------+------- 1 | AA | 1 2 | AB | 8 4 | BB | 5 5 | BD | 7 (4 rows)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69990629/viewspace-2853046/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 解析postgresql 刪除重複資料案例SQL
- mysql 刪除表中重複的資料MySql
- Oracle中刪除表中的重複資料Oracle
- 刪除表裡重複資料
- sqlserver中刪除重複資料SQLServer
- oracle 查詢及刪除表中重複資料Oracle
- mysql 查詢及 刪除表中重複資料MySql
- 刪除重複資料
- Oracle中刪除重複資料的SqlOracleSQL
- mysql查詢表裡的重複資料方法和刪除重複資料MySql
- mongodb刪除重複資料MongoDB
- MySQL刪除重複資料MySql
- Oracle如何刪除表中重複記錄Oracle
- 查詢刪除表中重複記錄
- 使用Java Stream API中DistinctBy刪除重複資料JavaAPI
- 高效快速刪除Oracle表中重複記錄Oracle
- 重複資料刪除:備份中的“消重加速器”
- SQL Server中刪除重複資料的幾個方法SQLServer
- Oracle查詢重複資料與刪除重複記錄Oracle
- Oracle 刪除表中重複記錄的DELETE SQLOracledeleteSQL
- MS SQL Server 刪除重複行資料SQLServer
- T-SQL 刪除重複資料SQLSQL
- 海量資料處理_刪除重複行
- 根據rowid刪除重複資料
- 通過ROWID刪除重複資料
- excel刪除重複資料保留一條 如何刪掉重複資料只留一條Excel
- mysql表刪除重複記錄方法MySql
- Oracle查詢重複資料與刪除重複記錄方法Oracle
- PostgreSQL表增加/刪除欄位是否會重寫表SQL
- JavaScript刪除字串中重複字元JavaScript字串字元
- Oracle 使用分析函式刪除表中的重複行Oracle函式
- ORACLE批量刪除無主鍵重複資料Oracle
- Python 字串,list排序,刪除重複資料Python字串排序
- Mongodb 刪除重複資料的幾個方法MongoDB
- oracle重複資料的查詢及刪除Oracle
- oracle 刪除重複資料的幾種方法Oracle
- Oracle 刪除重複資料只留一條Oracle
- 刪除重複資料的幾個方法(轉)