LeetCode:Database 19.查询员工的累计薪水

要求:请你编写 SQL 语句,对于每个员工,查询他除最近一个月(即最大月)之外,剩下每个月的近三个月的累计薪水(不足三个月也要计算),结果请按 Id 升序,然后按 Month 降序显示。

Employee 表:

| Id | Month | Salary |
|----|-------|--------|
| 1  | 1     | 20     |
| 2  | 1     | 20     |
| 1  | 2     | 30     |
| 2  | 2     | 30     |
| 3  | 2     | 40     |
| 1  | 3     | 40     |
| 3  | 3     | 60     |
| 1  | 4     | 60     |
| 3  | 4     | 70     |
Employee 表保存了一年内的薪水信息

Result Table:

| Id | Month | Salary |
|----|-------|--------|
| 1  | 3     | 90     |
| 1  | 2     | 50     |
| 1  | 1     | 20     |
| 2  | 1     | 20     |
| 3  | 3     | 100    |
| 3  | 2     | 40     |

分析:
1.求每三个月的累计工资,因此需要使用窗口聚合函数sum() over()去求取当前月和下方两个月的工资之和
2.查询结果去除最大月使用窗口函数row_number() over()对month降序排序,去除最大的月即可

SQL语句:

SELECT  t.id,t.month,t.s1 AS Salary
FROM (
SELECT id,month,salary,
SUM(salary) over(PARTITION BY id ORDER BY month DESC
ROWS BETWEEN  current ROW AND 2 following) AS s1,
row_number() over(PARTITION BY id ORDER BY month DESC )AS r1
FROM 
Employee
)t
WHERE r1>1;
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值