智能建网站,主机公园wordpress,网页编辑软件免费版,商务网站设计与建设实训作者 | 磊哥来源 | Java面试真题解析#xff08;ID#xff1a;aimianshi666#xff09;转载请联系授权#xff08;微信ID#xff1a;GG_Stone#xff09;在 MySQL 中#xff0c;最常见的去重方法有两个#xff1a;使用 distinct 或使用 group by#xff0c;那它们有什… 作者 | 磊哥来源 | Java面试真题解析IDaimianshi666转载请联系授权微信IDGG_Stone在 MySQL 中最常见的去重方法有两个使用 distinct 或使用 group by那它们有什么区别呢接下来我们一起来看。1.创建测试数据-- 创建测试表
drop table if exists pageview;
create table pageview(id bigint primary key auto_increment comment 自增主键,aid bigint not null comment 文章ID,uid bigint not null comment 访问用户ID,createtime datetime default now() comment 创建时间
) default charsetutf8mb4;
-- 添加测试数据
insert into pageview(aid,uid) values(1,1);
insert into pageview(aid,uid) values(1,1);
insert into pageview(aid,uid) values(2,1);
insert into pageview(aid,uid) values(2,2);最终展现效果如下2.distinct 使用distinct 基本语法如下SELECT DISTINCT column_name,column_name FROM table_name;2.1 单列去重我们先用 distinct 实现单列去重根据 aid文章 ID去重具体实现如下2.2 多列去重除了单列去重之外distinct 还支持多列两列及以上去重我们根据 aid文章 ID和 uid用户 ID联合去重具体实现如下2.3 聚合函数去重使用 distinct 聚合函数去重计算 aid 去重之后的总条数具体实现如下3.group by 使用group by 基础语法如下SELECT column_name,column_name FROM table_name
WHERE column_name operator value
GROUP BY column_name3.1 单列去重根据 aid文章 ID去重具体实现如下与 distinct 相比 group by 可以显示更多的列而 distinct 只能展示去重的列。3.2 多列去重根据 aid文章 ID和 uid用户 ID联合去重具体实现如下3.3 聚合函数 group by统计每个 aid 的总数量SQL 实现如下从上述结果可以看出使用 group by 和 distinct 加 count 的查询语义是完全不同的distinct count 统计的是去重之后的总数量而 group by count 统计的是分组之后的每组数据的总数。4.distinct 和 group by 的区别官方文档在描述 distinct 时提到在大多数情况下 distinct 是特殊的 group by如下图所示官方文档地址https://dev.mysql.com/doc/refman/8.0/en/distinct-optimization.html但二者还是有一些细微的不同的比如以下几个。区别1查询结果集不同当使用 distinct 去重时查询结果集中只有去重列信息如下图所示当你试图添加非去重字段查询时SQL 会报错如下图所示而使用 group by 排序可以查询一个或多个字段如下图所示区别2使用业务场景不同统计去重之后的总数量需要使用 distinct而统计分组明细或在分组明细的基础上添加查询条件时就得使用 group by 了。使用 distinct 统计某列去重之后的总数量统计分组之后数量大于 2 的文章就要使用 group by 了如下图所示区别3性能不同如果去重的字段有索引那么 group by 和 distinct 都可以使用索引此情况它们的性能是相同的而当去重的字段没有索引时distinct 的性能就会高于 group by因为在 MySQL 8.0 之前group by 有一个隐藏的功能会进行默认的排序这样就会触发 filesort 从而导致查询性能降低。总结大部分场景下 distinct 是特殊的 group by但二者也有细微的区别比如它们在查询结果集上、使用的具体业务场景上以及性能上都是不同的。参考 鸣谢zhuanlan.zhihu.com/p/384840662是非审之于己毁誉听之于人得失安之于数。公众号Java面试真题解析面试合集https://gitee.com/mydb/interview往期推荐面试突击62group by 有哪些注意事项面试突击61说一下MySQL事务隔离级别面试突击60什么情况会导致 MySQL 索引失效