题目描述
查找所有员工的last_name和first_name以及对应的dept_name,也包括暂时没有分配部门的员工
CREATE TABLE `departments` (
`dept_no` char(4) NOT NULL,
`dept_name` varchar(40) NOT NULL,
PRIMARY KEY (`dept_no`));
CREATE TABLE `dept_emp` (
`emp_no` int(11) NOT NULL,
`dept_no` char(4) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_no`));
CREATE TABLE `employees` (
`emp_no` int(11) NOT NULL,
`birth_date` date NOT NULL,
`first_name` varchar(14) NOT NULL,
`last_name` varchar(16) NOT NULL,
`gender` char(1) NOT NULL,
`hire_date` date NOT NULL,
PRIMARY KEY (`emp_no`));
输出描述
分析
题目有三个表:
- 【部门的信息】
departments
: dept_no, dept_name - 【部门员工所属】
dept_emp
: emp_no, dept_no,... - 【员工的信息】
employees
: emp_no, first_name, last_name,...
包括暂时没有分配部门的员工,说明表3采用采用LEFT JOIN。
dept_name信息位于表1,将表1表2通过dept_no内连接。再通过emp_no与表3左连接
select e.last_name,e.first_name,b.dept_name
from employees as e left outer join
(select * from departments inner join dept_emp
on departments.dept_no=dept_emp.dept_no) as b
on e.emp_no=b.emp_no