服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL 去重实例操作详解

MySQL 去重实例操作详解

2022-07-19 09:25Java中文社群 Mysql

这篇文章主要介绍了MySQL 去重实例操作详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下

 

前言

MySQL 中,最常见的去重方法有两个:使用 distinct 或使用 group by,那它们有什么区别呢?接下来我们一起来看。

 

1.创建测试数据

最终展现效果如下: 

MySQL 去重实例操作详解

 

2.distinct 使用

distinct 基本语法如下:

SELECT DISTINCT column_name,column_name FROM table_name;

 

2.1 单列去重

我们先用 distinct 实现单列去重,根据 aid(文章 ID)去重,具体实现如下: 

MySQL 去重实例操作详解

 

2.2 多列去重

除了单列去重之外,distinct 还支持多列(两列及以上)去重,我们根据 aid(文章 ID)和 uid(用户 ID)联合去重,具体实现如下: 

MySQL 去重实例操作详解

 

2.3 聚合函数+去重

使用 distinct + 聚合函数去重,计算 aid 去重之后的总条数,具体实现如下: 

MySQL 去重实例操作详解

 

3.group by 使用

group by 基础语法如下:

SELECT column_name,column_name FROM table_name 
WHERE column_name operator value 
GROUP BY column_name

 

3.1 单列去重

根据 aid(文章 ID)去重,具体实现如下: 

MySQL 去重实例操作详解

 与 distinct 相比 group by 可以显示更多的列,而 distinct 只能展示去重的列。

 

3.2 多列去重

根据 aid(文章 ID)和 uid(用户 ID)联合去重,具体实现如下: 

MySQL 去重实例操作详解

 

3.3 聚合函数 + group by

统计每个 aid 的总数量,SQL 实现如下: 

MySQL 去重实例操作详解

 从上述结果可以看出,使用 group by 和 distinct 加 count 的查询语义是完全不同的,distinct + count 统计的是去重之后的总数量,而 group by + count 统计的是分组之后的每组数据的总数。

 

4.distinct 和 group by 的区别

官方文档在描述 distinct 时提到:在大多数情况下 distinct 是特殊的 group by如下图所示: 

MySQL 去重实例操作详解

 官方文档地址:但二者还是有一些细微的不同的,比如以下几个。

 

区别1:查询结果集不同

当使用 distinct 去重时,查询结果集中只有去重列信息,如下图所示: 

MySQL 去重实例操作详解

 当你试图添加非去重字段(查询)时,SQL 会报错如下图所示: 

MySQL 去重实例操作详解

 而使用 group by 排序可以查询一个或多个字段,如下图所示: 

MySQL 去重实例操作详解

 

区别2:使用业务场景不同

统计去重之后的总数量需要使用 distinct,而统计分组明细,或在分组明细的基础上添加查询条件时,就得使用 group by 了。

使用 distinct 统计某列去重之后的总数量: 

MySQL 去重实例操作详解

 统计分组之后数量大于 2 的文章,就要使用 group by 了,如下图所示: 

MySQL 去重实例操作详解

 

区别3:性能不同

如果去重的字段有索引,那么 group by 和 distinct 都可以使用索引,此情况它们的性能是相同的;而当去重的字段没有索引时,distinct 的性能就会高于 group by,因为在 MySQL 8.0 之前,group by 有一个隐藏的功能会进行默认的排序,这样就会触发 filesort 从而导致查询性能降低。

 

总结

大部分场景下 distinct 是特殊的 group by,但二者也有细微的区别,比如它们在查询结果集上、使用的具体业务场景上,以及性能上都是不同的。

到此这篇关于MySQL 去重实例操作详解的文章就介绍到这了,更多相关MySQL 去重内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文地址:https://juejin.cn/post/7117061586484723743

延伸 · 阅读

精彩推荐
  • Mysqlwin10下安装两个MySQL5.6.35数据库

    win10下安装两个MySQL5.6.35数据库

    这篇文章主要为大家详细介绍了win10下两个MySQL5.6.35数据库安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...

    everythingss3502020-07-28
  • Mysqlmysql5.7 生成列 generated column用法实例分析

    mysql5.7 生成列 generated column用法实例分析

    这篇文章主要介绍了mysql5.7 生成列 generated column用法,结合实例形式分析了mysql5.7 生成列 generated column基本原理、用法及操作注意事项,需要的朋友可以参考下...

    怀素真13502021-01-08
  • Mysqlwin10 64位 MySQL8.0下载和安装教程图解

    win10 64位 MySQL8.0下载和安装教程图解

    这篇文章主要介绍了MySQL下载和安装 win10 64位 MySQL8.0的教程图解,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...

    百度经验4652020-12-04
  • Mysqlmysql 开放外网访问权限的方法

    mysql 开放外网访问权限的方法

    今天小编就为大家分享一篇mysql 开放外网访问权限的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    Sam_qifa2562020-09-01
  • MysqlMySQL中日期比较时遇到的编码问题解决办法

    MySQL中日期比较时遇到的编码问题解决办法

    这篇文章主要介绍了MySQL中日期比较时遇到的字符集问题解决办法,本文遇到的问题是date_format函数和timediff函数之间比较时,编码问题导致出错,本文使用con...

    junjie1862020-04-12
  • MysqlMySQL GROUP_CONCAT限制解决方案

    MySQL GROUP_CONCAT限制解决方案

    这篇文章主要介绍了MySQL GROUP_CONCAT限制解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值...

    果果虫5862021-02-02
  • Mysql深入浅析MySQL COLUMNS分区

    深入浅析MySQL COLUMNS分区

    COLUMN分区是5.5开始引入的分区功能,只有RANGE COLUMN和LIST COLUMN这两种分区;支持整形、日期、字符串;RANGE和LIST的分区方式非常的相似。下面就两者的区别...

    pursuer.chen4952020-06-29
  • MysqlMySQL解压版配置步骤详细教程

    MySQL解压版配置步骤详细教程

    这篇文章主要介绍了MySQL解压版配置步骤详细教程的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下 ...

    zhong_fucheng4202020-07-04