8

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

http://www.nowcoder.com/questionTerminal/ae51e6d057c94f6d891735a48d1c2397

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

方法1:distinct+order by
select distinct salary
from salaries
where to_date='9999-01-01'
order by salary desc;

方法2:distinct+order by
select salary
from salaries
where to_date='9999-01-01'
group by salary
order by salary desc;
补充:WHERE语句在GROUP BY语句之前,SQL会在分组之前计算WHERE语句。HAVING语句在GROUP BY语句之后,SQL会在分组之后计算HAVING语句。

说明:
对于distinct与group by的使用:
1.当对系统的性能高并且数据量大时使用group by
2.当对系统的性能不高时或者使用数据量少时两者借口
3.尽量使用group by

全部评论
为什么要加where to_date='9999-01-01' 这个过滤条件呢?
9 回复 分享
发布于 2021-02-24 00:01
反手就是一个赞,前几天数据分析师说,数据量很大情况下,能用group by就不要用distinct,恰巧在这看到了解释。
4 回复 分享
发布于 2022-03-05 20:44
没有说所有在职的员工,所有员工是包括在职和离职的,所以条件可以不用加吧
3 回复 分享
发布于 2021-06-19 21:07
方法2应该是,group by+order by 吧
1 回复 分享
发布于 2021-07-30 09:33
请问这道题后面为什么一定要用oder by 排序呢?为什么不用oder by salary desc就提交不上去呢?
1 回复 分享
发布于 2021-06-09 22:24
如果两个人薪水一样 直接按照薪水分组 还是查所有人的薪水吗
1 回复 分享
发布于 2021-06-08 08:26

相关推荐

点赞 评论 收藏
分享
评论
103
7
分享

创作者周榜

更多
牛客网
牛客企业服务