在MySQL中,DISTINCT关键字用于从查询结果中删除重复的行。当您在多表查询中使用DISTINCT时,它将从所有选定的表中删除重复的行,而不仅仅是单个表中的重复行。
以下是一个使用DISTINCT在多表查询中的示例:
假设我们有两个表:employees和departments,它们的结构如下:
employees表
| id | name | department_id |
|---|---|---|
| 1 | Alice | 1 |
| 2 | Bob | 2 |
| 3 | Carol | 1 |
| 4 | Dave | 3 |
departments表
| id | name |
|---|---|
| 1 | HR |
| 2 | Finance |
| 3 | IT |
现在,我们想要查询每个部门的唯一员工数量。我们可以使用以下SQL查询:
SELECT DISTINCT d.name AS department_name, COUNT(e.id) AS employee_count
FROM employees e
JOIN departments d ON e.department_id = d.id
GROUP BY d.name;
这个查询首先通过JOIN子句将employees表和departments表连接在一起,然后使用GROUP BY子句按部门名称对结果进行分组。DISTINCT关键字在这里用于确保每个部门的名称只出现一次,同时COUNT(e.id)函数计算每个部门的员工数量。
查询结果将如下所示:
+---------------+----------------+
| department_name | employee_count |
+---------------+----------------+
| Finance | 2 |
| HR | 2 |
| IT | 1 |
+---------------+----------------+
可以看到,DISTINCT关键字成功地删除了重复的部门名称,同时计算了每个部门的员工数量。
以上就是关于“MYSQL DISTINCT在多表查询中的应用”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm