前进之路 发表于 2024-6-14 22:48:06

postgresql根据某个字段去重获取整行数据

背景:在一些情况下我们需要对数据举行去重统计,group by就行,但是一些特别情况下我们要根据某个字段去重之后获取非聚合字段的值,这个时间在mysql非严格模式下可以直接执行,但是在严格模式和postgresql里面是直接报错的,不能直接查询非聚合列
这个情况下postgresql里面有个语法可以支持到
select distinct on(age) * from t_user;

https://img-blog.csdnimg.cn/direct/823245a8a76d4427a481870298ae291e.png
别的一中写法是分组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;

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: postgresql根据某个字段去重获取整行数据