SQL之DISTINCT

本文提醒在使用SQL的DISTINCT关键字时应注意其作用范围为所有列而非仅限指定列。通过实例说明了不当使用可能导致的数据检索错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

警告:不能部分使用DISTINCT。 DISTINCT关键字作用于所有的列,不仅仅是跟在其后的那一列。例如,你指定SELECT DISTINCT vend_id, prod_price,除非指定的两列完全相同,否则所有的行都会被检索出来。

转载于:https://www.cnblogs.com/thiaoqueen/p/7012218.html

### SQL DISTINCT 使用方法及示例 #### 1. 基本概念 `DISTINCT` 关键字用于在 `SELECT` 语句中,指示数据库返回唯一不同的值。这可以应用于单个列或多个列的组合,确保结果集中的每一行都是唯一的[^3]。 #### 2. 使用语法 基本语法如下所示: ```sql SELECT DISTINCT column1, column2, ... FROM table_name; ``` 此语法允许用户指定一列或多列作为去重的目标。对于多列的情况,只有当这些列的所有值都相同时才会被认为是重复项。 #### 3. 示例说明 ##### 示例 1: 单列去重 假设有一个名为 `employees` 的表,其中包含员工的名字和其他信息。如果想要获取所有不同名字而不考虑是否有同名同事,则可执行以下查询: ```sql SELECT DISTINCT name FROM employees; ``` 这条命令将会返回一个列表,里面只含有独一无二的名字条目[^1]。 ##### 示例 2: 多列组合去重 继续沿用上面的例子,现在不仅关心姓名还要关注部门编号(department_id),那么可以通过下面的方式实现两者的联合去重: ```sql SELECT DISTINCT name, department_id FROM employees; ``` 这样做的效果是在最终的结果集中不会存在两个完全相同的(name, department_id)对。 ##### 示例 3: 聚合函数中使用 `COUNT(DISTINCT ...)` 有时可能需要统计某些特定字段内不重复记录的数量。比如要计算公司里有多少位不同的经理人员,就可以这样做: ```sql SELECT COUNT(DISTINCT manager_id) FROM employees; ``` 这里利用了 `COUNT()` 函数配合 `DISTINCT` 来达到目的,并且需要注意的是 `COUNT()` 自动忽略 NULL 值[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值