SQL每日一题(20210607)求出在每一个工资发放日,每个部门的平均工资与公司的平均工资的比较结果 (高 / 低 / 相同)

该博客探讨了SQL查询中的比较分析,通过案例展示了如何对比不同部门在不同时间段内的平均支付金额,使用CASE语句进行'HIGHER', 'SAME', 'LOWER'的分类,并进行了分组和排序。此外,还提供了另一种利用窗口函数AVG()进行比较的方法,进一步优化了查询效率。
摘要由CSDN通过智能技术生成

SQL每日一题(20210903)
SQL每日一题(20220322)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

SELECT b.pay_date,
       b.department_id,
       CASE
           WHEN b.avgb >
                a.avga THEN 'HIGHER'
           WHEN b.avgb = a.avga THEN 'SAME'
           ELSE 'LOWER' END comparison
FROM (SELECT date_format(ta.pay_date, '%Y-%m') pay_date, AVG(ta.amount) avga
      FROM t0607a ta
      GROUP BY date_format(ta.pay_date, '%Y-%m')) a,
     (SELECT tb.department_id, date_format(ta.pay_date, '%Y-%m') pay_date, AVG(ta.amount) avgb
      FROM t0607a ta,
           t0607b tb
      WHERE ta.employee_id = tb.employee_id
      GROUP BY date_format(ta.pay_date, '%Y-%m'), tb.department_id) b
WHERE a.pay_date = b.pay_date
ORDER BY b.department_id, b.pay_date;

在这里插入图片描述
在这里插入图片描述

select PAY_MONTH,
       DEPARTMENT_ID,
       CASE
           WHEN sum(money) >
                sum(avg_money) THEN 'HIGHER'
           WHEN sum(money) <
                sum(avg_money) THEN 'LOWER'
           ELSE 'SAME' END COMPARISON
from (select date_format(Pay_Date, '%Y-%m')                            PAY_MONTH,
             Department_ID,amount,
             avg(amount) over (partition by Department_ID,Pay_Date) as money,
             avg(amount) over (partition by Pay_Date)                  avg_money
      from T0607a a
               inner join T0607b b on a.Employee_ID = b.Employee_ID) cc
group by DEPARTMENT_ID, PAY_MONTH
order by DEPARTMENT_ID
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

time丶sand

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值