查找所有员工的last_name和first_name以及对应的dept_name--18

题目描述
查找所有员工的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));
查找所有员工的last_name和first_name以及对应的dept_name--18_第1张图片
解析:
1.找到没有被分配的部门号的name就是左连接,两次左连接就行。

select A.last_name,A.first_name,C.dept_name from  employees A left join dept_emp B on A.emp_no=B.emp_no
left join departments C on B.dept_no=C.dept_no

你可能感兴趣的:(mysql刷题)