背景:在一些情况下我们需要对数据进行去重统计,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;