天天看點

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