牛客网数据库SQL实战06—— 查找所有员工入职时候的薪水情况

牛客网数据库SQL实战06—— 查找所有员工入职时候的薪水情况

题目描述

查找所有员工入职时候的薪水情况,给出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`));

输入描述:

输出描述:

emp_no salary
10011 25828
省略 省略
10001 60117

我的解答

select e.emp_no,s.salary
from employees e
left join salaries s
on e.emp_no = s.emp_no and e.hire_date = s.from_date
order by e.emp_no desc 

此题应注意以下四个知识点:

  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 可以省略

我觉得最好的答案

完全不需要employees这个表。。

select emp_no, salary from salaries
group by emp_no
having from_date = min(from_date)
order by emp_no desc
发布了136 篇原创文章 · 获赞 58 · 访问量 36万+

猜你喜欢

转载自blog.csdn.net/sunbocong/article/details/105480231