zoukankan      html  css  js  c++  java
  • Oracle的rollup语句详解

    在多行查询中,使用rollup语句能够大大提高我们的操作效率,在开始接触rollup语句
    的时候,总是不能理解其中的顺序,查了一些资料和前辈们的博客,实践操作了几次,在此总结一下,首先rollup是卷起的意思,大体能够形容他的作用。
    group by rollup(a,b)
    这条语句相当于分组三次
    第一次,a,b两个约束条件,即a相同,b也相同的分为同一组
    第二次,只是用a一个条件进行分组,把上一次形成的结果在进行分组,把a相同的分为一组
    第三次,没有约束条件,将整个表数据分为一组
    这样三次之后,我们就有了三个分组条件,那么sum函数,就会给每一个分组都执行一次计算总和
    举例如下:
     
     1 SQL> select deptno,job,sum(sal) from emp group by deptno,job order by deptno;
     2 单独使用分组查询
     3  
     4 DEPTNO JOB         SUM(SAL)
     5 ------ --------- ----------
     6     10 CLERK           1300
     7     10 MANAGER         2450
     8     10 PRESIDENT       5000
     9     20 ANALYST         6000
    10     20 CLERK           1900
    11     20 MANAGER         2975
    12     30 CLERK            950
    13     30 MANAGER         2850
    14     30 SALESMAN        5600
    15  
    16 已选择9行。
    17  
    18 SQL> select deptno,job,sum(sal) from emp group by rollup(deptno,job) order by deptno;
    19  
    20 DEPTNO JOB         SUM(SAL)
    21 ------ --------- ----------
    22     10 CLERK           1300 第一次分组的sum总和计算
    23     10 MANAGER         2450
    24     10 PRESIDENT       5000
    25     10                 8750 第二次分组添加的计算
    26     20 ANALYST         6000
    27     20 CLERK           1900
    28     20 MANAGER         2975
    29     20                10875
    30     30 CLERK            950
    31     30 MANAGER         2850
    32     30 SALESMAN        5600
    33     30                 9400
    34                       29025 第三次分组添加的计算
    35 所以rollup函数进行多次分组计算
    36  
    37 已选择13行。
     
  • 相关阅读:
    TSql随机获取一条
    Delphi 删除目录
    Sqlserver 分组累加(处理一分一段表)
    当上班没事做的时候,做什么?
    网站中图片滚动效果的实现方法集锦
    Gridview用法大全。
    开发常见问题总结(二)
    仿京东,qq相册效果的前台和后台实现的开发总结。
    分享一款不错多个图片上传工具
    开发常见问题总结(三)
  • 原文地址:https://www.cnblogs.com/anzhi/p/7515747.html
Copyright © 2011-2022 走看看