SQL 54) 排除最大、最小salary之后的当前员工的平均工资

查找排除当前最大、最小salary之后的员工的平均工资avg_salary

http://www.nowcoder.com/questionTerminal/95078e5e1fba4438b85d9f11240bc591

方法)NOT IN
SELECT AVG(salary)
FROM salaries
WHERE salary NOT IN(
    SELECT MAX(salary) 
    FROM salaries 
    WHERE to_date = '9999-01-01')
AND salary NOT IN (
    SELECT MIN(salary) 
    FROM salaries 
    WHERE to_date = '9999-01-01')
AND to_date = '9999-01-01';
用NOT IN + 子查询筛选排除掉最大值和最小值

SQL 文章被收录于专栏

SQL

全部评论
这么做是有问题的,因为最大或者最小工资的对应员工不一定是唯一的,会有重复。那么不管是否有重复,都只去掉一个最大值,一个最小值。
点赞 回复 分享
发布于 2021-02-25 21:48

相关推荐

11-24 00:11
已编辑
广东工业大学 算法工程师
避雷深圳  yidao,试用期 6 个月。好嘛,试用期还没结束,就直接告诉你尽快找下一家吧,我谢谢您嘞
牛客75408465号:笑死,直属领导和 hr 口径都没统一,各自说了一些离谱的被裁理由,你们能不能认真一点呀,哈哈哈哈哈😅😅😅
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
4
收藏
分享
牛客网
牛客企业服务