ToB企服应用市场:ToB评测及商务社交产业平台

标题: postgresql根据某个字段去重获取整行数据 [打印本页]

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

别的一中写法是分组topN也可以实现类似的本领
  1. SELECT *
  2. FROM (
  3.     SELECT *,
  4.            ROW_NUMBER() OVER (PARTITION BY age ORDER BY id DESC) AS row_num
  5.     FROM t_user
  6. ) AS user_data
  7. WHERE row_num = 1;
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4