SQL> select emp_id,month,prd_type_id,amount
2 from all_sales
3 where emp_id=21
4 order by emp_id,month ;

EMP_ID      MONTH PRD_TYPE_ID     AMOUNT
---------- ---------- ----------- ----------
        21          1           4    3034.84
        21          1           3    6034.84
        21          1           2    1034.84
        21          1           5
        21          1           1   10034.84
        21          2           3    1944.65
        21          2           4    2944.65
        21          2           1   15144.65
注:表中数据太多,只显示了一部分。
表all_sales存放2003年每个员工每个产品每个月的销量,
SQL> select emp_id,month,sum(amount)
2 from all_sales
3 where emp_id=21
4 group by emp_id,month
5 order by month ;

EMP_ID      MONTH SUM(AMOUNT)
---------- ---------- -----------
        21          1    20139.36
        21          2     21578.6
        21          3    30251.32
        21          4     35729.8
        21          5    25358.24
        21          6    28258.56
        21          7    36449.36
        21          8    62639.28
        21          9    49418.28
        21         10    80016.76
        21         11    41018.92
        21         12    36139.36
用ROLLUP 进行分组

SQL> select emp_id,month,sum(amount)
2 from all_sales
3 where emp_id=21
4 group by rollup(emp_id,month) ;

EMP_ID      MONTH SUM(AMOUNT)
---------- ---------- -----------
        21          1    20139.36
        21          2     21578.6
        21          3    30251.32
        21          4     35729.8
        21          5    25358.24
        21          6    28258.56
        21          7    36449.36
        21          8    62639.28
        21          9    49418.28
        21         10    80016.76
        21         11    41018.92
        21         12    36139.36
        21              466997.84
                        466997.84

ROLLUP(emp_id,month):先对每个EMP_id的每个月的销量
进行分组求和,相当于GROUP BY EMP_ID,MONTH,得出这个员工,
每个月的销量总和,然后求这个员工一年所有的销量,相当于
GROUP BY EMP_ID,最后所求所有员工的销量总和,
因为查询限制只返回EMP_ID=21的数据,所以
最后两条记录的值相同。
group by rollup(emp_id,month) 与group by emp_id,month
不同之处在于是,group by rollup(emp_id,month) 求得每个员工的
月销量之后,又多做了两个工作,一是求得每个员一年所有的销量,
二是求所有员工的年总销量。
如果除去where emp_id=21,则最后一条记录返回所有员工的总销量,如:
SQL> select emp_id,month,sum(amount)
2 from all_sales
3 group by rollup(emp_id,month) ;

EMP_ID      MONTH SUM(AMOUNT)
---------- ---------- -----------
        21          1    20139.36
        21          2     21578.6
        21          3    30251.32
        21          4     35729.8
        21          5    25358.24
        21          6    28258.56
        21          7    36449.36
        21          8    62639.28
        21          9    49418.28
        21         10    80016.76
        21         11    41018.92
        21         12    36139.36
        21              466997.84
        22          1    21939.36
        22          2     21078.6     
        23          6    15658.56
        23          7    33649.3 
        23         11    30518.92
        23         12    24139.36
        23              323077.84
        24          1    14669.36
        24          2     28878.6
        24          3    35651.32   
        24         10    30116.76
        24         11    22621.92
        24         12    24139.36
        24              333370.84
        25          1     7269.36
        25          2     13678.6     
        25         11    12821.92
        25         12    12639.36
        25              187970.84
        26          1    16568.75   
        26         11    14821.38
        26         12    15639.37
        26              228769.93
                       1972485.13
数据太多,只显示一部分。
可以看出,group by rollup(emp_id,month) 为每个员工的销量进行了
汇总,得出了月销量和年销量(每个员工的最后一条),同时为所有员工进行了汇总,得出所有
员工的年总销量(最后一条记录)

函数:grouping 
接收列作为参数,如果列为空,则grouping返回1,否则返回0,该函数与rollup搭配使用。
可以使用grouping函数对上述查询进行处理。
SQL> SELECT DECODE(GROUPING(EMP_ID), 1, '所有员工', EMP_ID) EMP_ID,
2         nvl2(emp_id,DECODE(GROUPING(MONTH), 1, '员工年度', MONTH),'所有员工年度') ND,
3         SUM(AMOUNT)
4    FROM ALL_SALES
5   GROUP BY ROLLUP(EMP_ID, MONTH)
6 ; 
EMP_ID                                   ND                                       SUM(AMOUNT)
---------------------------------------- ---------------------------------------- -----------
21                                       1                                           20139.36
21                                       2                                            21578.6
21                                       3                                           30251.32
21                                       12                                          36139.36
21                                       员工年度                                   466997.84
26                                       7                                           12549.36
26                                       8                                           23139.28
26                                       9                                           19318.28
26                                       10                                          26116.99
26                                       11                                          14821.38
26                                       12                                          15639.37
26                                       员工年度                                   228769.93
所有员工                                 所有员工年度                              1972485.13

oracle GROUP BY rollup的更多相关文章

  1. oracle group by rollup,decode,grouping,nvl,nvl2,nullif,grouping_id,group_id,grouping sets,RATIO_TO

    干oracle 047文章12当问题,经验group by 声明.因此邂逅group by  rollup,decode,grouping,nvl,nvl2,nullif,RATIO_TO_REPOR ...

  2. Oracle Group by+rollup+cube 的应用

    首先我们创建一个示例表: Create table test_group (v_name varchar2(4) ,v_size varchar2(4) ,v_color varchar2(4) ,n ...

  3. oracle group by rollup实现小计、合计

    SQL合计汇总实现数据N+1条显示: 注意group by rollup((ename, job, empno))!!! select decode(grouping(ename) + groupin ...

  4. oracle group by中cube和rollup字句的使用方法及区别

    oracle group by中rollup和cube的区别:  Oracle的GROUP BY语句除了最基本的语法外,还支持ROLLUP和CUBE语句. 如果是ROLLUP(A, B, C)的话,先 ...

  5. [Oracle] Group By 语句的扩展 - Rollup、Cube和Grouping Sets

    常常写SQL语句的人应该知道Group by语句的主要使用方法是进行分类汇总,以下是一种它最常见的使用方法(依据部门.职位分别统计业绩): SELECT a.dname,b.job,SUM(b.sal ...

  6. oracle按照指定列分组合计group by rollup()

    group by rollup() 按分组合计 select grouping(status),status,owner,object_type,count(*) from dba_objects w ...

  7. Oracle:grouping和rollup

    Oracle grouping和rollup简单测试 SQL,,,) group by department_id order by department_id; DEPARTMENT_ID SUM( ...

  8. GROUP BY ROLLUP和CUBE 用法

    ROLLUP和CUBE 用法           Oracle的GROUP BY语句除了最基本的语法外,还支持ROLLUP和CUBE语句. 如果是Group by  ROLLUP(A, B, C)的话 ...

  9. Oracle分析函数 — sum, rollup, cube, grouping用法

    本文通过例子展示sum, rollup, cube, grouping的用法. //首先建score表 create table score( class  nvarchar2(20), course ...

随机推荐

  1. Django_model进阶

    Django-model进阶   QuerySet 可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET 子句. >>> Ent ...

  2. myeclipse_JUnit导包问题

    第一种方式: MyEclipse创建JUnit单元测试时,在需要测试的代码段前键入“@Test”时,按ctrl和1一般会自动提示JUnit需要导包,但有时会无法提示这个建议,如图所示.该经验教你如何解 ...

  3. ubuntu 16.04 apt-get 出现The package 'xxx' needs to be reinstalled, but I can't find an archive for it.

    参考网址:http://www.ihaveapc.com/2011/10/fix-annoying-the-package-needs-to-be-reinstalled-but-i-cant-fin ...

  4. C++之PIMPL模式

    1 PIMPL解释 PIMPL(Private Implementation 或 Pointer to Implementation)是通过一个私有的成员指针,将指针所指向的类的内部实现数据进行隐藏. ...

  5. 如何用Adb连接Android手机 & unable to connect to 192.168.1.100:5555的原因和解决方法

    利用adb来连接手机, 有两种方式: 1, wifi 2, usb. 1. 通过wifi, 利用adb来连接手机. 在pc的cmd中输入命令: adb connect 192.168.1.100 其中 ...

  6. GMap.NET 显示GIF图标的定制

    利用System.Drawing.ImageAnimator类实现GIF图标显示 public class GMapMarkerImage : GMapMarker { private Image i ...

  7. vuex本地存储

    vuex与localstorage 区别:vuex数据存储的内存,localstorage的数据存储在本地 应用场景:vuex用于组件之间的传值,localstorage用于不同页面之间的传值 永久性 ...

  8. 修改Linux内核参数提高Nginx服务器在高的时候的性能

    并发 Linux下高并发的Nginx服务器,当TCP TIME_WAIT套接字数量经常达到两.三万,服务器很容易被拖死.通过修改Linux内核参数,可以减少Nginx服务器的TIME_WAIT套接字数 ...

  9. silverlight xap应用程序库

  10. Lotus and Characters (stronger)

    题意: 有n类物品,第i种物品权值为$val(i)$,有$cnt(i)$个,现在你可以选出一些物品排成一个序列(假设有m个), 记第i个物品种类为$x_i$,最大化$\sum_{i=1}^m{i * ...