背景:在一些情况下我们需要对数据进行去重统计,group by就行,但是一些特殊情况下我们要根据某个字段去重之后获取非聚合字段的值,这个时候在mysql非严格模式下可以直接执行,但是在严格模式和postgresql里面是直接报错的,不能直接查询非聚合列
这个情况下postgresql里面有个语法可以支持到
select distinct on(age) * from t_user;
另外一中写法是分组topN也可以实现类似的能力
SELECT *
FROM (
SELECT *,
ROW_NUMBER() OVER (PARTITION BY age ORDER BY id DESC) AS row_num
FROM t_user
) AS user_data
WHERE row_num = 1;
本站资源均来自互联网,仅供研究学习,禁止违法使用和商用,产生法律纠纷本站概不负责!如果侵犯了您的权益请与我们联系!
转载请注明出处: 免费源码网-免费的源码资源网站 » postgresql根据某个字段去重获取整行数据
发表评论 取消回复