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-删除重复数据保留一条的主要内容,如果未能解决你的问题,请参考以下文章