sql语句自连接使用场景 案例

自连接是指在一个表中进行连接操作,连接的两个表其实是同一张表的不同实例。自连接通常用于处理包含层级关系或者父子关系的数据。

一个常见的场景是组织结构表,其中包含了员工和其经理之间的关系。这种情况下,可以使用自连接来查询员工及其对应的经理信息。

假设有一个名为 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

这样就能够查询到每个员工及其对应的经理信息了。

相关推荐

  1. sql语句连接使用场景 案例

    2024-04-12 00:46:02       16 阅读
  2. SQL语言: 内外连接

    2024-04-12 00:46:02       14 阅读
  3. SQL语句常用语法(开发场景中)

    2024-04-12 00:46:02       28 阅读
  4. (Oracle)SQL优化案例:大表hash连接优化

    2024-04-12 00:46:02       11 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-12 00:46:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-12 00:46:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-12 00:46:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-12 00:46:02       20 阅读

热门阅读

  1. 蓝桥第 6 场 强者挑战赛 谁是帕鲁|数位DP模板

    2024-04-12 00:46:02       15 阅读
  2. @Configuration大悟!

    2024-04-12 00:46:02       15 阅读
  3. 【2】c++多线程技术之多线程标准库的使用

    2024-04-12 00:46:02       14 阅读
  4. Vue3中props的原理与使用

    2024-04-12 00:46:02       15 阅读
  5. python使用dataclass数据类有个坑

    2024-04-12 00:46:02       14 阅读
  6. 【QT教程】QT6布局管理

    2024-04-12 00:46:02       16 阅读