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

    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行。
    复制代码

     

    为人:谦逊、激情、博学、审问、慎思、明辨、 笃行
    学问:纸上得来终觉浅,绝知此事要躬行
    为事:工欲善其事,必先利其器。
    态度:道阻且长,行则将至;行而不辍,未来可期
    转载请标注出处!
  • 相关阅读:
    C++泛型函数及模版类
    android逆向入门及工具下载
    排序算法之交换排序
    索尼法则=?职场法则
    2014年5月20日---一个值得纪念的日子
    C#的委托是什么?
    物联网RFID安全研究
    [转]nmap使用方法
    [转]中间人攻击-ARP毒化
    15019:Only the instance admin may alter the PermSize attribute
  • 原文地址:https://www.cnblogs.com/ios9/p/14344864.html
Copyright © 2011-2022 走看看