java按照基本工资排序,23、对所有员工的薪水按照salary进行1-N的排名

对所有员工的当前(to_date=‘9999-01-01‘)薪水按照salary进行按照1-N的排名,相同salary并列且按照emp_no升序排列

CREATE TABLE `salaries` (

`emp_no` int(11) NOT NULL,

`salary` int(11) NOT NULL,

`from_date` date NOT NULL,

`to_date` date NOT NULL,

PRIMARY KEY (`emp_no`,`from_date`));

输入描述:

输出描述:

emp_nosalaryrank

10005

94692

1

10009

94409

2

10010

94409

2

10001

88958

3

10007

88070

4

10004

74057

5

10002

72527

6

10003

43311

7

10006

43311

7

10011

25828

8

2、代码:这道题主要难点就是rank列如何生成,只有一个表,那就使用自关联,这样可以添加过滤条件,a.salary<=b.salary,从而用count(distinct b.salary),就可以生成排名了,其思想就是对每一个工资,求他的排名就是求有多少是小于等于它的值的工资即可,最后进行去重,因为排名是从1开始,因此边界条件要加上=。

select a.emp_no,a.salary,count(distinct b.salary) asrankfrom salaries a joinsalaries bon a.to_date=‘9999-01-01‘ and b.to_date=‘9999-01-01‘ and a.salary<=b.salarygroup bya.emp_noorder by a.salary desc,a.emp_no asc;

本题的主要思想是复用salaries表进行比较排名,具体思路如下:

1、先对一张表的salary进行排序

2、进行并列操作,加入 count

3.这样只是统计了,这个salary出现的次数,并没有依照次序进行排序,要进行次序的排序,必须count,大于等于该条salary的数据条数,又因为数据有重复,所以distinct,此处必须使用表的重复使用功能

3、因为使用了合计函数导致,count只返回一个值,表a选择返回的值却有好几个,所以必须进行分组查询

4、最后在s1.salary 逆序排之后,再以 s1.emp_no 顺序排列输出结果,必须满足第一个条件的情况下,满足第二个排序条件,等于进行的是相同的rank,数据有重复的值进行了emp_no的排序

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值