SQL54 平均工资

文章目录

1. 题目

  • 题目来源:SQL54 平均工资

  • 题目描述
    查找排除在职(to_date = ‘9999-01-01’ )员工的最大、最小salary之后,其他的在职员工的平均工资avg_salary。

  • 一张表

    10001|85097.000|2001-06-22|2002-06-22
    10001|88958.000|2002-06-22|9999-01-01
    10002|72527.000|2001-08-02|9999-01-01
    10003|43699.000|2000-12-01|2001-12-01
    10003|43311.000|2001-12-01|9999-01-01
    10004|70698.000|2000-11-27|2001-11-27
    10004|74057.000|2001-11-27|9999-01-01
    
  • 所需结果

    avg_salary
    73292 
    

2. 题解

只需要求解 salary 字段的平均值,但是需要过滤掉在职员工的最大最小值。
思路:
使用子查询,对条件进行行过滤,有两种方法:
① 使用最值聚合函数MAX()MIN()
② 使用最值窗口函数MAX() OVER()MIN() OVER()

# 方法一:WHERE后子查询
SELECT AVG(salary) avg_salary
FROM salaries
WHERE to_date = '9999-01-01'
      AND salary != (SELECT MAX(salary) FROM salaries WHERE to_date = '9999-01-01')
      AND salary != (SELECT MIN(salary) FROM salaries WHERE to_date = '9999-01-01')
      
# 方法二:FROM后子查询
SELECT AVG(salary) avg_salary
FROM (SELECT *,
             MAX(salary) OVER() max_salary, 
             MIN(salary) OVER() min_salary
      FROM salaries
      WHERE to_date = '9999-01-01'
     ) t
WHERE to_date = '9999-01-01'
      AND salary != t.max_salary
      AND salary != t.min_salary

需要注意前置条件【在职员工】,是在职员工的最大最小值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值