又是随手刷到一道牛客SQL题,这次是👉查找排除最大、最小salary之后的当前(to_date = ‘9999-01-01’ )员工的平均工资avg_salary。此题其实不算难,一开始掌柜想到的解题思路如下:👇
- 首先找到最大最小工资,然后剔除这个数值;
- 接下来筛选当前日期为’9999-01-01’ 的平均工资数据即可。
但是这题其实又有点坑🤔,因为题意并没有明显说👉要你在剔除最大最小工资那里也是筛选当前日期为’9999-01-01’ !!! 这个条件,所以如果你一开始没有get到这个隐藏点就按掌柜一开始的思路来提交查询就会报错。。。
按照牛客这个正解来看的思路应该是:
- 首先剔除当前日期在’9999-01-01’ 的最大最小值;
- 接下来筛选当前日期为’9999-01-01’ 的数据;
- 最后合并这两个筛选条件求平均工资即可。
具体解法掌柜就不写了,再来看看此题主要考察知识点:👉NOT IN 函数、聚合函数以及子查询的用法。
看过掌柜之前题解的朋友应该都知道,掌柜习惯自己解完题再去看看题解区的优秀解法,然后就看到有好几个朋友有下面👇这样的一个疑问:
然后掌柜就去试了一下,发现如果剔除最大最小工资的时候,把MIN(salary)和MAX(salary)一起写再筛选确实会报错!!!
-
那么问题就来了,
🤔为什么不能把MAX(salary),M