秋招SQL实战 : 6.查找所有员工入职时候的薪水情况
题目描述:
查找所有员工入职时候的薪水情况,给出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
));
输入描述:
无
输出描述:
last_name | first_name | dept_no |
---|---|---|
emp_no | salary | |
-------- | ---------------- | |
10011 | 25828 | |
省略 | 省略 | |
10001 | 60117 |
题目解析:
解法一:
因为 salaries 的数据比 employees 的数据多(员工会涨薪)所以我们要有 e.emp_no = s.emp_no
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;
解法二:
使用内联结和FROM并列两表都可以,但要注意新入职日期的匹配。
内联结和自联结的区别:
内联结是取左右两张表的交集形成一个新表。FROM并列两表后仍然还是两张表。如果还要对新表进行操作则要用内连接。从效率上看应该FROM并列查询比较快,因为不用形成新表。
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;