SQL08 找出所有员工当前薪水salary情况

本文最后更新于:2022年4月9日 中午


题目描述

找出所有员工当前(to_date=’9999-01-01’)具体的薪水salary情况,对于相同的薪水只显示一次,并按照逆序显示

1
2
3
4
5
6
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`));

输入描述

输出描述

salary
94692
94409
88958
88070
74057
72527
59755
43311
25828

题解

1
2
3
select distinct salary from salaries where to_date='9999-01-01' order by salary desc;

select salary from salaries where to_date='9999-01-01' group by salary order by salary desc;

备注:

对于distinct与group by的使用:

1、当对系统的性能高并数据量大时使用group by

2、当对系统的性能不高时使用数据量少时两者皆可

3、尽量使用group by