題目描述
查找所有員工的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