由一道牛客SQL题引发关于NOT IN 函数、MAX函数、MIN函数的思考

又是随手刷到一道牛客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

  • 15
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值