详细分析MySQL中的distinct函数(附Demo)

2024-04-23 23:04

本文主要是介绍详细分析MySQL中的distinct函数(附Demo),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 前言
  • 1. 基本知识
  • 2. 基础Demo
  • 3. 进阶Demo

前言

该函数主要用于去重,对于细节知识,此文详细补充说明

1. 基本知识

DISTINCT 是一种用于查询结果中去除重复行的关键字

在查询数据库时,可能会得到重复的结果行,但有时只需要这些结果的唯一副本,这时就可以使用 DISTINCT 来过滤结果,确保每行只出现一次

类似如下:

SELECT DISTINCT name FROM students;

关于 DISTINCT 的基本知识和使用情况的详细分析:

  • DISTINCT 关键字紧跟在 SELECT 后面,用于指示要返回唯一值
  • DISTINCT 用于过滤查询结果中的重复行,确保每行只出现一次
  • 使用 DISTINCT 可能会影响查询性能,特别是当查询的列包含大量重复值时。因为数据库需要对结果集进行排序和去重操作,如果可能的话,应该在查询中仅选择需要的列,以减少不必要的计算量。在某些情况下,使用 GROUP BY 也可以达到类似的效果,但它更适用于需要对结果进行聚合的情况

2. 基础Demo

创建两张表格:

CREATE TABLE students (student_id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(50),age INT
);INSERT INTO students (name, age) VALUES
('Alice', 20),
('Bob', 22),
('Charlie', 21),
('Alice', 20),
('David', 23);

另外一张表格:

CREATE TABLE courses (course_id INT AUTO_INCREMENT PRIMARY KEY,course_name VARCHAR(50),student_id INT,FOREIGN KEY (student_id) REFERENCES students(student_id)
);INSERT INTO courses (course_name, student_id) VALUES
('Math', 1),
('Physics', 2),
('Chemistry', 3),
('Math', 4),
('Biology', 5);
  1. 查询所有学生的姓名和年龄:SELECT DISTINCT name, age FROM students; (注意此处有个Bug,那就是我的Alice 20 是有两条记录的)
    在这里插入图片描述
  2. 查询所有学生的姓名和他们所选的课程:
SELECT s.name, c.course_name
FROM students s
JOIN courses c ON s.student_id = c.student_id;

在这里插入图片描述

  1. 查询每门课程的选课人数:
SELECT course_name, COUNT(student_id) AS num_students
FROM courses
GROUP BY course_name;

在这里插入图片描述

3. 进阶Demo

以上的Demo比较普遍
如果涉及不常规的逻辑:

  1. 使用多个字段进行查重:返回所有不重复的姓名和年龄的组合

(修改数据)
在这里插入图片描述

SELECT DISTINCT name, age
FROM students;

此处截图如下:

在这里插入图片描述

如果此时想获取最大的age可以这么使用:

SELECT GROUP_CONCAT(DISTINCT name), MAX(age) AS age
FROM students
GROUP BY name;

截图如下:

在这里插入图片描述

  1. 处理 NULL 值:在查询中进行特殊处理
    使用 COALESCE() 函数将 NULL 值转换为一个特定的占位符,然后再进行查重
SELECT DISTINCT COALESCE(name, ''), COALESCE(age, 0)
FROM students;
  1. 考虑使用聚合函数:
    如果想要统计每组唯一值的数量,可以结合 COUNT() 函数使用
SELECT name, age, COUNT(*)
FROM students
GROUP BY name, age;

这篇关于详细分析MySQL中的distinct函数(附Demo)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/930126

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

MySQL中VARCHAR和TEXT的区别小结

《MySQL中VARCHAR和TEXT的区别小结》MySQL中VARCHAR和TEXT用于存储字符串,VARCHAR可变长度存储在行内,适合短文本;TEXT存储在溢出页,适合大文本,下面就来具体的了解... 目录一、VARCHAR 和 TEXT 基本介绍1. VARCHAR2. TEXT二、VARCHAR

MySQL中C接口的实现

《MySQL中C接口的实现》本节内容介绍使用C/C++访问数据库,包括对数据库的增删查改操作,主要是学习一些接口的调用,具有一定的参考价值,感兴趣的可以了解一下... 目录准备mysql库使用mysql库编译文件官方API文档对象的创建和关闭链接数据库下达sql指令select语句前言:本节内容介绍使用C/

mybatis直接执行完整sql及踩坑解决

《mybatis直接执行完整sql及踩坑解决》MyBatis可通过select标签执行动态SQL,DQL用ListLinkedHashMap接收结果,DML用int处理,注意防御SQL注入,优先使用#... 目录myBATiFBNZQs直接执行完整sql及踩坑select语句采用count、insert、u

MySQL之搜索引擎使用解读

《MySQL之搜索引擎使用解读》MySQL存储引擎是数据存储和管理的核心组件,不同引擎(如InnoDB、MyISAM)采用不同机制,InnoDB支持事务与行锁,适合高并发场景;MyISAM不支持事务,... 目录mysql的存储引擎是什么MySQL存储引擎的功能MySQL的存储引擎的分类查看存储引擎1.命令

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数