天天看點

查找所有員工入職時候的薪水給出emp_no以及salary并按照emp_no進行逆序

查找所有員工入職時候的薪水情況,給出emp_no以及salary, 并按照emp_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

));

CREATE TABLE

salaries

(

emp_no

int(11) NOT NULL,

salary

int(11) NOT NULL,

from_date

date NOT NULL,

to_date

date NOT NULL,

PRIMARY KEY (

emp_no

,

from_date

));

此題應注意以下四個知識點:

1、由于測試資料中,salaries.emp_no不唯一(因為号碼為emp_no的員工會有多次漲薪的可能,是以在salaries中對應的記錄不止一條),employees.emp_no唯一,即salaries的資料會多于employees,是以需先找到employees.emp_no在salaries表中對應的記錄salaries.emp_no,則有限制條件e.emp_no = s.emp_no

2、根據題意注意到salaries.from_date 和employees.hire_date的值應該要相等,是以有限制條件 e.hire_date = s.from_date

3、根據題意要按照emp_no值逆序排列,是以最後要加上 ORDER BY e.emp_no DESC

4、為了代碼良好的可讀性,運用了Alias别名語句,将employees簡化為e,salaries簡化為s,即 employees AS e與salaries AS s,其中AS可以省略

方法一:利用 INNER JOIN 連接配接兩張表

SELECT e.emp_no, s.salary FROM employees AS e INNER JOIN salaries AS s
ON e.emp_no = s.emp_no AND e.hire_date = s.from_date
ORDER BY e.emp_no DESC
           

方法二:直接用逗号并列查詢兩張表

SELECT e.emp_no, s.salary FROM employees AS e, salaries AS s
WHERE e.emp_no = s.emp_no AND e.hire_date = s.from_date
ORDER BY e.emp_no DESC
           

題目來源于牛客網