天天看点

SQL(12)--查找所有员工last_name和first_name以及对应的dept_name(三表)

题目描述

查找所有员工的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`));

输出描述

SQL(12)--查找所有员工last_name和first_name以及对应的dept_name(三表)

分析

题目有三个表:

  1. 【部门的信息】

    departments

    : dept_no, dept_name
  2. 【部门员工所属】

    dept_emp

    : emp_no, dept_no,...
  3. 【员工的信息】

    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
           
sql