• 微信公众号:美女很有趣。 工作之余,放松一下,关注即送10G+美女照片!

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

开发技术 开发技术 5小时前 2次浏览

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-删除重复数据保留一条
喜欢 (0)