自连接是指在一个表中进行连接操作,连接的两个表其实是同一张表的不同实例。自连接通常用于处理包含层级关系或者父子关系的数据。
一个常见的场景是组织结构表,其中包含了员工和其经理之间的关系。这种情况下,可以使用自连接来查询员工及其对应的经理信息。
假设有一个名为 employees
的表,包含了员工的信息,表结构如下:
| employee_id | employee_name | manager_id |
|-------------|---------------|------------|
| 1 | Alice | NULL |
| 2 | Bob | 1 |
| 3 | Charlie | 1 |
在这个表中,employee_id
是员工的唯一标识,employee_name
是员工的姓名,manager_id
是该员工的直接经理的 employee_id
。如果一个员工没有直接经理,那么 manager_id
就为 NULL
。
现在我们想要查询员工及其对应的经理姓名,可以使用自连接来实现:
SELECT e.employee_name AS employee,
m.employee_name AS manager
FROM employees e
LEFT JOIN employees m
ON e.manager_id = m.employee_id;
这条 SQL 查询首先从 employees
表中选择员工的姓名,然后再次从 employees
表中选择经理的姓名,通过 LEFT JOIN
连接两次选择的结果,连接条件是员工表中的 manager_id
等于经理表中的 employee_id
。
这样就能够查询到每个员工及其对应的经理信息了。