200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > SQL-6查找所有员工入职时候的薪水情况 给出emp_no以及salary 并按照emp_no进行逆序...

SQL-6查找所有员工入职时候的薪水情况 给出emp_no以及salary 并按照emp_no进行逆序...

时间:2023-01-03 22:32:26

相关推荐

SQL-6查找所有员工入职时候的薪水情况 给出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:

SQL:

select e.emp_no,s.salaryfrom employees e join salaries son e.emp_no=s.emp_no and e.hire_date=s.from_dateorder by e.emp_no desc

运行 19ms-22ms

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 可以省略 链接:/questionTerminal/23142e7a23e4480781a3b978b5e0f33a牛客网优秀解答 解答2:(来自牛客网 优秀解答) 不要要连接 直接用工资表

select emp_no,salary from salariesgroup by emp_no having(min(from_date))order by emp_no desc

对其直接进行分组 找出其最小的入职时间 运行时间在 17ms

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。