当前位置: 首页 > article >正文

mysql学习教程,从入门到精通,SQL DISTINCT 子句 (16)

1、SQL DISTINCT 子句

SQL 的 DISTINCT 子句是一个强大的工具,用于在查询结果中消除重复的行,只保留唯一的数据记录。当处理数据库中的数据时,经常会遇到同一列或多列中存在重复值的情况。DISTINCT 子句可以帮助我们专注于唯一的值,这对统计和报告特别有用。

1.1、SQL DISTINCT 子句的定义

DISTINCT 是 SQL 语言中用来消除查询结果中重复记录的关键字。它可以用来从表中获取唯一的值或避免结果中的重复行。当从表中检索数据时,可能会发现某些字段包含多个重复值,此时 DISTINCT 就变得非常有用。

1.2、SQL DISTINCT 子句的使用方法

使用 DISTINCT 子句的基本语法结构如下:

SELECT DISTINCT column1, column2, ..., columnN
FROM table_name;

这里的 column1, column2, ..., columnN 是希望获取其唯一值的数据库表的列名或字段名的列表,而 table_name 是要从中选择数据的表的名称。
如果在 SELECT 语句中指定了多个字段,那么 DISTINCT 将会考虑所有指定字段的组合来确定哪些行是唯一的。

1.3、示例

假设我们有一个名为 Employees 的表,其中包含员工的信息。如果我们只想获取所有不同的姓氏,我们可以使用 DISTINCT 关键字:

SELECT DISTINCT LastName
FROM Employees;

如果一个表中有多个员工拥有相同的姓氏,如 Smith,那么使用 DISTINCT 后,查询结果只会显示一次 Smith

1.4、多列去重

如果我们想要查询没有重复项的姓名和年龄的组合,可以这样做:

SELECT DISTINCT FirstName, LastName, Age
FROM Students;

这条语句会返回姓名、姓氏和年龄的唯一组合。

1.5、 DISTINCTGROUP BY 的区别

需要注意的是,DISTINCTGROUP BY 都可以用来消除重复记录,但是它们的工作方式不同。DISTINCT 是基于整个行来消除重复,而 GROUP BY 则是对特定的列进行分组,然后对每一组执行聚合操作。

1.6、DISTINCT 与索引

DISTINCT 的性能取决于是否能够利用到表上的索引来加速去重过程。如果表中存在适当的索引,那么 DISTINCT 的执行效率会更高。

1.7、 结合使用 WHERE 子句

可以将 DISTINCTWHERE 子句结合起来使用,以便进一步过滤结果集:

SELECT DISTINCT column1, column2
FROM table_name
WHERE condition;

这种组合可以让你获取满足特定条件的唯一结果。
以上就是关于 SQL DISTINCT 子句的基本介绍和使用方法,它是一个非常实用的功能,能够帮助用户更好地理解和分析数据库中的数据。
当然,下面是一些使用 DISTINCT 子句的具体案例分析,以展示它在实际应用中的用法。

1.8、SQL DISTINCT案列分析

案例 1:获取唯一的产品类别

假设有一个销售数据表 Sales,其中包含产品 ID (ProductID) 和产品类别 (Category)。为了找出所有不同的产品类别,可以使用以下查询:

SELECT DISTINCT Category
FROM Sales;

此查询将返回一个列表,其中包含所有不同的产品类别。

案例 2:统计唯一客户的数量

在一个订单表 Orders 中,如果想找出有多少个不同的客户进行了订购,可以通过 DISTINCT 来统计唯一客户:

SELECT COUNT(DISTINCT CustomerID)
FROM Orders;

这条语句返回的结果将是所有不同客户 ID 的数量。

案例 3:按部门统计唯一的员工职位

假设有一个 Employees 表,其中包括员工的部门 (Department) 和职位 (Position)。如果想知道每个部门有多少种不同的职位,可以使用 DISTINCT 并结合 GROUP BY

SELECT Department, COUNT(DISTINCT Position) AS NumberOfPositions
FROM Employees
GROUP BY Department;

此查询将列出每个部门及其对应的唯一职位数量。

案例 4:找出特定条件下的唯一记录

如果你想要找出特定月份内所有唯一的交易日期,假设有一个 Transactions 表,包含交易日期 (TransactionDate) 和金额 (Amount),可以这样做:

SELECT DISTINCT TransactionDate
FROM Transactions
WHERE MONTH(TransactionDate) = 3; -- 假设查找三月份的数据

这条语句将返回三月份所有的不同交易日期。

案例 5:多列唯一组合

如果想要找出所有不同的订单组合,包括订单日期和客户 ID,可以从 Orders 表中使用:

SELECT DISTINCT OrderDate, CustomerID
FROM Orders;

这将返回所有不同的订单日期和客户 ID 组合。

总结

DISTINCT 子句在 SQL 查询中非常有用,特别是在需要去除重复数据并关注唯一记录的情况下。通过上面的例子可以看出,DISTINCT 可以单独使用来获取某一列或多列的唯一值,也可以与其他 SQL 子句如 COUNT, GROUP BY 结合使用来提供更加丰富的信息。


http://www.kler.cn/news/312385.html

相关文章:

  • DeDeCMS靶场漏洞复现
  • 前端vue-父传子
  • 2024年亲测好用的四大在线翻译工具大盘点!
  • keras和tensorflow可用的一组版本
  • 【百日算法计划】:每日一题,见证成长(013)
  • MySQL练手题--获得最近第二次的活动(困难)
  • 【JVM】符号引用 和 直接引用
  • 中国计算机学会(CCF)推荐中文科技期刊目录(2019年)
  • nacos报Client not connected, current status:STARTING
  • Stable Diffusion绘画 | ControlNet应用-IP-Adapter:堪比 Midjourney 垫图
  • Ubuntu在CMakeLists.txt中指定OpenCV版本的参考方法
  • 【QT基础】创建项目项目代码解释
  • Python和Java的自动化测试技术研究及应用探索
  • Linux Vim编辑器常用命令
  • 【源码+文档+调试讲解】健身房管理平台小程序
  • 【Linux修行路】网络套接字编程——UDP
  • 828华为云征文 | 云服务器Flexus X实例:one-api 部署,支持众多大模型
  • 信息化时代下的高标准农田灌区:变革与机遇并存
  • 使用Docker Compose一键部署
  • 105.游戏安全项目-基址的技术原理-分析技巧
  • 游戏性能优化
  • 硬件工程师笔试面试学习汇总——器件篇目录
  • 梳理归档文档
  • 鸿蒙开发之ArkUI 界面篇 十四 个人中心导航界面
  • 数据结构 ——— 常见的时间复杂度计算例题(上篇)
  • 使用Spring Boot和Spring WebFlux实现响应式打字效果
  • 使用 Python 高分解决 reCAPTCHA v3 的指南
  • orangepi部署web环境
  • 基于SpringBoot的考研资讯平台设计与实现
  • 李宏毅2022深度学习作业代码记录(hw1)—— COVID19