pg快速删除表部分数据

pg快速删除表部分数据,第1张

使用TRUNCATE TABLE命令来删除PostgreSQL表中数据。PostgreSQL是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ORDBMS),其中pg快速删除表部分数据是可以使用TRUNCATE TABLE命令来删除。Truncate是一个能够快速清空资料表内所有资料的SQL语法。

1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断

[sql] 

select * from people  

where peopleId in (select  peopleId  from  people  group  by  peopleId  having  count(peopleId) > 1)  

 

2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录

[sql] 

delete from people   

where peopleId  in (select  peopleId  from people  group  by  peopleId   having  count(peopleId) > 1)  

and rowid not in (select min(rowid) from  people  group by peopleId  having count(peopleId )>1)  

 

3、查找表中多余的重复记录(多个字段) 

[sql] 

select * from vitae a  

where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq  having count(*) > 1)  

 

4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录

[sql] 

delete from vitae a  

where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)  

and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)  

 

5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录

[sql] 

select * from vitae a  

where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)  

and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9933884.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存