PostgreSQL 库如何去除单表重复数据呢?可以通过 ctid 进行,下面是实验过程。
一、创建测试表
| 代码如下 | 复制代码 |
| david=# create table emp ( david(# id int, david(# name varchar); CREATE TABLE david=# |
|
二、插入测试数据
| 代码如下 | 复制代码 |
|
|
|
三、查询初始化数据
| 代码如下 | 复制代码 |
|
david=# |
|
查询重复数据数
| 代码如下 | 复制代码 |
|
david=# |
|
查询出 id 为1的记录有3条,id 为2的记录有2条。
四、查询要保留的数据
以 min(ctid) 或 max(ctid) 为准。
| 代码如下 | 复制代码 |
|
david=# |
|
五、删除重复数据
| 代码如下 | 复制代码 |
|
david=# delete from emp where ctid not in (select min(ctid) from emp group by id); |
|
六、查看最后结果
| 代码如下 | 复制代码 |
|
|
|
david=# 说明:如果表中已经有标明唯一的序列主键值,可以把该值替换上述的ctid直接删除
模拟极限越野
模拟极限越野开着大巴在各种奇葩路况里送乘客。山路弯道多得让人
模拟火车
模拟火车让你当回真正的火车司机,得先学会看信号灯、操作控制杆
可口的披萨美味的披萨
可口的披萨美味的披萨带您体验经营一家披萨店的乐趣。游戏画风温
定制虚拟偶像最新版
定制虚拟偶像最新版是一款超级经典有趣的日本模拟装扮类型的手游
病娇模拟器手机版正版(yandere simulator)
病娇模拟器最新版手游是一款萌妹二次元模拟游戏,玩家在游戏中可