黄东旭解析 TiDB 的核心优势
741
2023-06-10
面试突击:MySQL 中如何去重?
作者 | 磊哥
来源 | Java面试真题解析(ID:aimianshi666)
在 MySQL 中,最常见的去重方法有两个:使用 distinct 或使用 group by,那它们有什么区别呢?接下来我们一起来看。
1、创建测试数据
最终展现效果如下:
2、distinct 使用
distinct 基本语法如下:
SELECT DISTINCT column_name,column_name FROM table_name;
(1)单列去重
我们先用 distinct 实现单列去重,根据 aid(文章 ID)去重,具体实现如下:
(2)多列去重
除了单列去重之外,distinct 还支持多列(两列及以上)去重,我们根据 aid(文章 ID)和 uid(用户 ID)联合去重,具体实现如下:
(3)聚合函数+去重
使用 distinct + 聚合函数去重,计算 aid 去重之后的总条数,具体实现如下:
3、group by 使用
group by 基础语法如下:
SELECT column_name,column_name FROM table_name WHERE column_name operator value GROUP BY column_name
(1)单列去重
根据 aid(文章 ID)去重,具体实现如下:
与 distinct 相比 group by 可以显示更多的列,而 distinct 只能展示去重的列。
(2)多列去重
根据 aid(文章 ID)和 uid(用户 ID)联合去重,具体实现如下:
(3)聚合函数 + group by
4、distinct 和 group by 的区别
官方文档在描述 distinct 时提到:在大多数情况下 distinct 是特殊的 group by,如下图所示:
区别1:查询结果集不同
当使用 distinct 去重时,查询结果集中只有去重列信息,如下图所示:
当你试图添加非去重字段(查询)时,SQL 会报错如下图所示:
区别2:使用业务场景不同
统计去重之后的总数量需要使用 distinct,而统计分组明细,或在分组明细的基础上添加查询条件时,就得使用 group by 了。使用 distinct 统计某列去重之后的总数量:
区别3:性能不同
如果去重的字段有索引,那么 group by 和 distinct 都可以使用索引,此情况它们的性能是相同的;而当去重的字段没有索引时,distinct 的性能就会高于 group by,因为在 MySQL 8.0 之前,group by 有一个隐藏的功能会进行默认的排序,这样就会触发 filesort 从而导致查询性能降低。
总结
大部分场景下 distinct 是特殊的 group by,但二者也有细微的区别,比如它们在查询结果集上、使用的具体业务场景上,以及性能上都是不同的。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。