2025年SQL语句distinct的多个字段去重问题

SQL语句distinct的多个字段去重问题经典例子 select distinct name id from table 或者 select name id from table group by name 像这样是错误的写法 distinct 不起作用的 曲线救国写法 select name id from table where id in select min id from table group by name


经典例子

select distinct name, id from table

或者

select name,id from table group by name

像这样是错误的写法,distinct不起作用的

曲线救国写法:

select name,id from table where id in (

select min(id) from table group by name

)

思想:将需要去重的字段添加到where条件中,取出唯一id

然后就可以获得去重之后的两个字段了

不过我这边是你需要去重一个字段,展示两个字段的情况

# 注意

有很多朋友问,group by是可以对多字段进行去重的,但是我这里为什么还说不行呢?
我在这里统一描述下

由于时间比较早了,我大概记得当时的场景是:对一个字段进行去重,而需要取两个字段,这样的写法如下

select A,B from table group by A

但是group by是不支持这种写法的,因为group by 和 select 中的字段必须保持一致


当前注意事项写于:2022年6月27日18:24:10

还可以看如下文章

Group_concat介绍与例子_HashMap黑龙江分Map的博客-CSDN博客_group_concat

mysql去重的最方便的两种方法_承影v的博客-CSDN博客_mysql去重

编程小号
上一篇 2025-01-17 16:01
下一篇 2025-01-17 15:51

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/148689.html