题目描述
查找所有员工的last_name和first_name以及对应部门编号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
`));
解答:
题目说的很清楚了,没有分配部门的员工也要显示,所有采用左连接,员工表为主表。
select e
.last_name
,e
.first_name
,de
.dept_no
from employees e
left join dept_emp de
on e
.emp_no
=de
.emp_no