MySQL Group By 分组后保留最新一条记录

错误方法:

select a.* from 
(select * from user order by id desc) a 
group by a.id

先在子查询中进行倒序排列,查询排列完成的数据


首先 评论区说的对,上面的确实不能用。但是也确实可以用,想省事的小伙伴可以试试,报错或者不能用的话就用下面的方案。上面的方案是跟数据库配置有关,MySQL配置了group by 查询的相关东西


下面是我本次更新时测试的结果

  • MySQL版本 -> 5.7.26 截图为证!
    在这里插入图片描述

  • 表中原始数据
    在这里插入图片描述

  • 正常分组查询结果
    在这里插入图片描述
    这个没毛病吧,就是正常的分组查询。不过是多了个any_value(),具体原因的话你么可以不加,然后测试一下,如果报错就去百度一下,很容易查到。没报错就不用加(最近遇到这个坑的。之前从来没发现过)

  • 符合需求的sql
    在这里插入图片描述
    需要注意的是,子查询里面有个limit 9999,这个要加上,才可以符合需求,不然就跟正常的分组查询结果一样。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值