postgresql-删除重复数据保留一条

Posted 月图灵

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了postgresql-删除重复数据保留一条相关的知识,希望对你有一定的参考价值。

1.常规删除方法
explain analyse delete from deltest a where a.ctid <> (select min(t.ctid) from deltest t where a.id=t.id);
2.group by删除方法
explain analyse delete from deltest a where a.ctid not in (select min(ctid) from deltest group by id);
3.row_number删除方法
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));

根据某个字段分组删除重复数据,只保留日期最大的一条,建议使用窗口函数效率更高

以上是关于postgresql-删除重复数据保留一条的主要内容,如果未能解决你的问题,请参考以下文章

mysql删除重复数据,保留一条

数据库怎样删除多条重复数据保留一条?

mysql 删除重复的数据保留一条

sql删除重复数据且只保留一条?

怎么删除ACCESS中的重复记录 只保留一条

Oracle删除重复记录只保留一条数据的几种方法