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行。
     
  • 相关阅读:
    如果获取 上传域的文件名
    更改织梦后台广告
    html5 让IE6,7支持HTML5语义化标签的文件
    如何获取选中的复选框
    手机下的ev.pageX无效
    Ajax
    列出远程git的全部分支
    扫描局域网中Gogs服务器(ruby)
    Xcode删除无用的Symbols信息
    Docker
  • 原文地址:https://www.cnblogs.com/anzhi/p/7515747.html
Copyright © 2011-2022 走看看