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行。
     
  • 相关阅读:
    初次接触json...
    vector algorithm find
    网站安全(13) ——目录穿越漏洞(Directory Traversal)
    网站安全(20) —— 语义URL攻击
    网站安全(7) —— PHP文件包含漏洞介绍
    让PHP更快的提供文件下载
    PHP中关于include()和require() 的区别问题
    PHP中 获取全路径的文件的扩展名
    MySQL varchar计算:求列的数目和计算N的最大值
    jmeter使用分享
  • 原文地址:https://www.cnblogs.com/anzhi/p/7515747.html
Copyright © 2011-2022 走看看