SQL语句之计算次数出现最多的值

需求,计算20号部门员工工资出现的次数
使用count() 函数:

SQL> select sal,count(*) time from emp where deptno=20 group by sal;

       SAL   TIME
---------- ----------
      2975      1
      1100      1
      3000      2
       800      1

SQL>

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

计算20号部门工资出现的次数,并排出序号
使用dense_rank分析函数

SQL> select sal,dense_rank() over(order by time desc) as seq
  2  from
  3  (select sal,count(*) time from emp where deptno=20 group by sal) emp;

       SAL    SEQ
---------- ----------
      3000      1
       800      2
      2975      2
      1100      2

SQL>

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

根据序号过滤得到序号为2的结果

SQL> select sal
  2  from
  3  (select sal,dense_rank() over(order by time desc) as seq
  4  from
  5  (select sal,count(*) time from emp where deptno=20 group by sal) emp) emp
  6  where seq=2;

       SAL
----------
      2975
       800
      1100

SQL>

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14

利用partition by 子句分别查询各个部门哪个工资等级的员工多

SQL> select deptno,sal
  2  from
  3  (select deptno,sal,dense_rank() over(partition by deptno order by time desc) as seq
  4  from
  5  (select deptno,sal,count(*) time from emp group by deptno,sal) emp ) emp
  6  where seq=1;

    DEPTNO    SAL
---------- ----------
    10   5000
    10   1300
    10   2450
    20   3000
    30   1250

SQL>

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16

以上就是计算次数出现最多的次数的方法。
---------------------
作者:小花粉的Sanctuary
来源:CSDN
原文:https://blog.csdn.net/sungsasong/article/details/78136736
版权声明:本文为博主原创文章,转载请附上博文链接!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值