深入解析mysql中distinct的用法

 更新时间:2025年09月15日 14:33:59   作者:有梦想的攻城狮  
本文深入解析了MySQL中DISTINCT关键字的功能,包括其作用、原理及使用方法,DISTINCT用于去除重复记录,提高数据查询效率,文章通过实例展示了如何对单个或多个字段进行去重,并结合COUNT函数使用,感兴趣的朋友跟随小编一起看看吧

DISTINCT简介

DISTINCT 的作用是消除结果集中的重复行,语法如下:

SELECT DISTINCT
    columns
FROM
    table_name
WHERE
    where_conditions; 

mysql中的distinct的用法

distinct的作用

在mysql中,distinct关键字的主要作用就是对数据库表中一个或者多个字段重复的数据进行过滤,只返回其中的一条数据给用户,distinct只可以在select中使用

distinct的原理

distinct进行去重的主要原理是通过先对要进行去重的数据进行分组操作,然后从分组后的每组数据中去一条返回给客户端,在这个分组的过程可能会出现两种不同的情况:

  • distinct 依赖的字段全部包含索引:
  • 该情况mysql直接通过操作索引对满足条件的数据进行分组,然后从分组后的每组数据中去一条数据。
  • distinct 依赖的字段未全部包含索引:
  • 该情况由于索引不能满足整个去重分组的过程,所以需要用到临时表,mysql首先需要将满足条件的数据放到临时表中,然后在临时表中对该部分数据进行分组,然后从临时表中每个分组的数据中去一条数据,在临时表中进行分组的过程中不会对数据进行排序。

distinct的用法

distinct的使用语法是这样的:

select distinct expression[,expression...] from tables [where conditions];

在使用distinct的过程中主要注意一下几点:

  • 在对字段进行去重的时候,要保证distinct在所有字段的最前面
  • 如果distinct关键字后面有多个字段时,则会对多个字段进行组合去重,只有多个字段组合起来的值是相等的才会被去重

下面我们通过在开发过程中经常遇到的一些关于distinct的实例来加深大家对该关键字用法的理解:

数据库表结构和数据如下图所示:

  • 对单个字段进行去重sql:
select distinct  age from user;
查询结果
age
10
20
30
  • 对多个字段进行去重sql:
select distinct name,age from user;
查询结果
name	age
One	10
Zero	20
Two	20
Four	30
One	30
  • 对多个字段进行去重并求count的sql:
select count(distinct name,age) as total from user;
查询结果
total
5
  • 对select * 进行去重
select distinct * from user;
由于 * 代表所有字段,所以该sql和 select distinct id,name,age,sign from user 语义相同
查询结果:
id		name	age		sign
1		One		10		梦想要有的,万一实现了呢
2		Zero	20		http://www.chaoshizhushou.com
3		Two		20		OneZeroTwoFour
4		Four	30		加油
5		One		30		学习才是硬道理
6		Four	30		一日三省吾身

到此这篇关于mysql中的distinct的用法的文章就介绍到这了,更多相关mysql distinct用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL分支和循环结构方式

    MySQL分支和循环结构方式

    在MySQL中,IF函数用于根据条件返回不同的值,类似于Java的三目运算符,CASE语句则提供了两种形式:简单CASE函数和搜索CASE函数,分别类似于Java中的switch-case结构和多重if判断,这些控制流函数在数据库查询和数据处理中非常有用,可以实现复杂的逻辑判断
    2024-10-10
  • Linux中部署MySQL环境的四种方式图文详解

    Linux中部署MySQL环境的四种方式图文详解

    这篇文章主要介绍了Linux中部署MySQL环境的四种方式,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-11-11
  • 在MySQL中用正则表达式替换数据库中的内容的方法

    在MySQL中用正则表达式替换数据库中的内容的方法

    在MySQL中用正则表达式替换数据库中的内容的方法...
    2007-03-03
  • MySQL多表联查的实现思路

    MySQL多表联查的实现思路

    数据库应用在我们的生活中是很常见的,在编辑一些应用以及软件的时候都需要用到数据库来存储数据,下面这篇文章主要给大家介绍了关于MongoDB中实现多表联查的相关资料,需要的朋友可以参考下
    2023-02-02
  • 常见php与mysql中文乱码问题解决办法

    常见php与mysql中文乱码问题解决办法

    MySQL对中文的支持程度还是很有限的,尤其是新手,但凡出现乱码问题,就会头大。
    2014-09-09
  • Mysql如何将数据按照年月分组的统计

    Mysql如何将数据按照年月分组的统计

    这篇文章主要介绍了Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-04-04
  • MySQL分页优化

    MySQL分页优化

    这篇文章主要为大家详细介绍了MySQL分页优化,内容思路很详细,有意对MySQL分页优化的朋友可以参考一下
    2016-04-04
  • mysql查看binlog日志的配置方法

    mysql查看binlog日志的配置方法

    文章介绍了如何配置和查看MySQL 8.0的binlog日志,包括开启binlog、查看当前日志位置、查看日志目录和信息,以及使用mysqlbinlog工具查看和分析binlog日志,感兴趣的朋友跟随小编一起看看吧
    2025-11-11
  • SQL通用语法以及分类图文详解

    SQL通用语法以及分类图文详解

    本书从初学者的角度出发,由浅入深,循序渐进地介绍了SQL通用语法的相关知识,下面这篇文章主要给大家介绍了关于SQL通用语法以及分类的相关资料,需要的朋友可以参考下
    2022-12-12
  • MySQL 8.0 之索引跳跃扫描(Index Skip Scan)

    MySQL 8.0 之索引跳跃扫描(Index Skip Scan)

    这篇文章主要介绍了MySQL 8.0 之索引跳跃扫描(Index Skip Scan)的相关资料,帮助大家学习MySQL8.0的新特性,感兴趣的朋友可以了解下
    2020-10-10

最新评论