秋招SQL实战 : 6.查找所有员工入职时候的薪水情况

秋招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;

你可能感兴趣的:(秋招SQL实战 : 6.查找所有员工入职时候的薪水情况)