温馨提示×

MYSQL DISTINCT在多表查询中的应用

小樊
84
2024-10-10 00:22:38
栏目: 云计算
亿速云mysql数据库,读写分离,安全稳定,弹性扩容,低至0.3元/天!! 点击查看>>

在MySQL中,DISTINCT关键字用于从查询结果中删除重复的行。当您在多表查询中使用DISTINCT时,它将从所有选定的表中删除重复的行,而不仅仅是单个表中的重复行。

以下是一个使用DISTINCT在多表查询中的示例:

假设我们有两个表:employeesdepartments,它们的结构如下:

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」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>

推荐阅读:mysql的distinct在多表查询中的应用

0