题目描述
查找所有员工的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`));
输出描述
分析
题目有三个表:
- 【部门的信息】
: dept_no, dept_namedepartments
- 【部门员工所属】
: emp_no, dept_no,...dept_emp
- 【员工的信息】
: emp_no, first_name, last_name,...employees
包括暂时没有分配部门的员工,说明表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