您当前的位置:首页 > 电脑百科 > 数据库 > MYSQL

MySQL 中如何去重?

时间:2023-07-12 15:08:18  来源:微信公众号  作者:Java面试真题解析
MySQL 中,最常见的去重方法有两个:使用 distinct 或使用 group by,那它们有什么区别呢?接下来我们一起来看。

作者 | 磊哥

来源 | JAVA面试真题解析(ID:AImianshi666)

转载请联系授权(微信ID:GG_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 charset='utf8mb4';
-- 添加测试数据
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;

(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

统计每个 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,但二者也有细微的区别,比如它们在查询结果集上、使用的具体业务场景上,以及性能上都是不同的。



Tags:MySQL   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除。
▌相关推荐
在数据处理和分析过程中,数据去重是一个常见的需求。Java开发者可以使用MySQL数据库提供的丰富功能和优化技术来实现高效的数据去重。下面将介绍Java开发者如何利用MySQL数据...【详细内容】
2023-09-07  Tags: MySQL  点击:(1)  评论:(0)  加入收藏
优雅处理Java与MySQL的并发访问冲突是开发分布式系统时需要考虑的重要问题。在多个线程或多个应用同时对MySQL数据库进行读写操作时,可能会出现数据一致性问题和性能问题。为...【详细内容】
2023-09-07  Tags: MySQL  点击:(3)  评论:(0)  加入收藏
前言我们在日常开发中,一定遇见过某些SQL执行较慢的情况,我们俗称“慢SQL”,如果你对系统的接口性能要求较高的话,一定不会放过这种SQL,肯定会想办法进行解决,那么,导致慢 SQL 出现...【详细内容】
2023-09-04  Tags: MySQL  点击:(14)  评论:(0)  加入收藏
一、案例背景 二、库表规范 1. 建表相关规范 2. 字段相关规范 3. 索引相关规范 4. 使用相关规范 三、建表语句 三、语句操作 1. 插入操作 2. 查...【详细内容】
2023-09-04  Tags: MySQL  点击:(19)  评论:(0)  加入收藏
在开发和管理数据库的过程中,经常会遇到字段长度不足的问题。特别是对于MySQL这样的关系型数据库,字段长度限制是不可避免的挑战。然而,我们可以采取一些解决方案来应对这个问...【详细内容】
2023-09-04  Tags: MySQL  点击:(19)  评论:(0)  加入收藏
有时候我们可能因为手抖或者粗心,执行了一条delete语句,导致正常的业务数据被删除了。别慌,也先别跑路。有很多种方式可以恢复回来,这一篇文章就来聊聊使用my2sql工具解析出dele...【详细内容】
2023-09-02  Tags: MySQL  点击:(15)  评论:(0)  加入收藏
canal 是阿里知名的开源项目,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费。这篇文章,我们手把手向同学们展示使用 canal 将 MySQL 增量数据同步到 ES 。1...【详细内容】
2023-08-31  Tags: MySQL  点击:(22)  评论:(0)  加入收藏
Mysql是我们经常使用到的数据库,因为很多时候是免费的,所以用的比较多,我们在设计表的时候应该会使用到索引,所以我们一起来聊下索引应该怎么去设置1、索引的定义什么叫索引 ,索...【详细内容】
2023-08-30  Tags: MySQL  点击:(29)  评论:(0)  加入收藏
简介在数据库查询中,模糊查询是一种强大的技术,可以用来搜索与指定模式匹配的数据。MySQL数据库提供了一个灵活而强大的LIKE操作符,使得模糊查询变得简单和高效。本文将详细介...【详细内容】
2023-08-30  Tags: MySQL  点击:(23)  评论:(0)  加入收藏
MySQL是一款广泛应用的关系型数据库管理系统,对于数据库设计而言,字段名的选择是至关重要的一环。不小心选择了和MySQL关键字相同的字段名可能导致严重的数据完整性问题。下面...【详细内容】
2023-08-29  Tags: MySQL  点击:(14)  评论:(0)  加入收藏
▌简易百科推荐
前言我们在日常开发中,一定遇见过某些SQL执行较慢的情况,我们俗称“慢SQL”,如果你对系统的接口性能要求较高的话,一定不会放过这种SQL,肯定会想办法进行解决,那么,导致慢 SQL 出现...【详细内容】
2023-09-04  dbaplus社群    Tags:慢SQL   点击:(14)  评论:(0)  加入收藏
此外本文也通过关于雇员薪酬调整的案例,渗透讲解 DDD 模型中的聚合对象、实体对象和值对象在领域模型中的实践。...【详细内容】
2023-09-04    小傅哥  Tags:   点击:(22)  评论:(0)  加入收藏
一、案例背景 二、库表规范 1. 建表相关规范 2. 字段相关规范 3. 索引相关规范 4. 使用相关规范 三、建表语句 三、语句操作 1. 插入操作 2. 查...【详细内容】
2023-09-04  小傅哥  微信公众号  Tags:MySQL   点击:(19)  评论:(0)  加入收藏
在开发和管理数据库的过程中,经常会遇到字段长度不足的问题。特别是对于MySQL这样的关系型数据库,字段长度限制是不可避免的挑战。然而,我们可以采取一些解决方案来应对这个问...【详细内容】
2023-09-04  编程技术汇  今日头条  Tags:MySQL   点击:(19)  评论:(0)  加入收藏
有时候我们可能因为手抖或者粗心,执行了一条delete语句,导致正常的业务数据被删除了。别慌,也先别跑路。有很多种方式可以恢复回来,这一篇文章就来聊聊使用my2sql工具解析出dele...【详细内容】
2023-09-02  dbaplus社群    Tags:MySQL   点击:(15)  评论:(0)  加入收藏
canal 是阿里知名的开源项目,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费。这篇文章,我们手把手向同学们展示使用 canal 将 MySQL 增量数据同步到 ES 。1...【详细内容】
2023-08-31  勇哥java实战分享    Tags:MySQL   点击:(22)  评论:(0)  加入收藏
Mysql是我们经常使用到的数据库,因为很多时候是免费的,所以用的比较多,我们在设计表的时候应该会使用到索引,所以我们一起来聊下索引应该怎么去设置1、索引的定义什么叫索引 ,索...【详细内容】
2023-08-30  南京路老R  今日头条  Tags:Mysql索引   点击:(29)  评论:(0)  加入收藏
简介在数据库查询中,模糊查询是一种强大的技术,可以用来搜索与指定模式匹配的数据。MySQL数据库提供了一个灵活而强大的LIKE操作符,使得模糊查询变得简单和高效。本文将详细介...【详细内容】
2023-08-30  ceshiren    Tags:模糊查询   点击:(23)  评论:(0)  加入收藏
概述 在MySQL中,FORCE INDEX是一种查询提示,用于强制查询优化器使用特定索引来执行查询。查询优化器在执行查询时,会根据统计信息和查询条件等来选择最优的执行计划,包括选择哪...【详细内容】
2023-08-26  雪竹聊技术  今日头条  Tags:MySQL   点击:(15)  评论:(0)  加入收藏
在开发和管理MySQL数据库时,我们经常会遇到字段长度过长的问题。当字段长度超过MySQL所支持的最大长度时,数据可能无法正确存储或查询,导致数据丢失或错误。为了解决这个问题,下...【详细内容】
2023-08-24  编程技术汇  今日头条  Tags:MySQL   点击:(21)  评论:(0)  加入收藏
站内最新
站内热门
站内头条