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

打印 上一主题 下一主题

主题 523|帖子 523|积分 1569

背景:在一些情况下我们需要对数据举行去重统计,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企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

前进之路

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表