mysql之使用外部联结的左联结

本文介绍如何使用MySQL的左联结查询来获取所有员工的last_name、first_name以及对应的部门编号dept_no,包括未分配部门的员工。重点在于理解左联结的原理,即即使右侧表中无对应数据,也会保留左侧表的所有记录。在实际操作中,应将大表置于外连接之前。

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

题目:查找所有员工的last_name和first_name以及对应部门编号dept_no,也包括暂时没有分配具体部门的员工(请注意输出描述里各个列的前后顺序)

可能会出现

在这里插入图片描述

在这里插入图片描述

知识点:
内联结,两边表同时有对应的数据,即任何一边缺失数据就不显示。
左联结,读取左边数据表的全部数据,即便右边表无对应数。即右表d中dept_no即使为NULL,也会读取左表e中的全部emp。
注意:是大表(数据量多的)在前,使用外连接

正确示范:

SELECT e.last_name, e.first_name, d.dept_no
FROM employees AS e
LEFT OUTER JOIN dept_emp AS d
ON e.emp_no=d.emp_no;

错误示范:
需要都满足条件,即

select a.last_name,a.first_name,b.dept_no from employees a inner join dept_emp b where a.emp_no=b.emp_no 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值