大家对GROUP BY应该比较熟悉,如果你感觉自己并不完全理解GROUP BY,那么本文不适合你。还记得当初学习SQL的时候,总是理解不了GROUP BY的作用,经过好长时间才终于明白GROUP BY的真谛。当然,这和我本人笨也有关系,但是GROUP BY的确不好理解。本文将介绍DB2 GROUPING SETS、ROLLUP、CUBE的使用方法,这些关键字比GROUP BY更难理解,所以阅读本文的时候,一定要慢,仔细的分析,你理解的越多,需要记忆的就越少。

我们首先来看GROUPING SETS的使用方法,请看下面的例子

  1. GROUP BY GROUPING SETS (A,B,C)  等价与  GROUP BY A
  2. UNION ALL
  3. GROUP BY B
  4. UNION ALL
  5. GROUP BY C

从字面上理解,GROUPING SETS就是GROUP集合的意思,确实是这样的,从上面的例子,我们可以很容易的理解GROUPING SETS的使用方法,但是使用括号的时候需要我们特别注意,请看下面的例子

  1. GROUP BY GROUPING SETS ((A,B,C))  等价与  GROUP BY A,B,C
  2. GROUP BY GROUPING SETS (A,(B,C))  等价与  GROUP BY A
  3. UNION ALL
  4. GROUP BY B,C

我们应该把括号里面的所有内容看做一个整体,这个整体必须在同一个GROUP BY语句中,例如,语句2中的B,C在括号中,B,C必须在同一个GROUP BY语句中,千万别把他们拆开,写出GROUP BY B UNION ALL GROUP BY C,那样就大错特错了。

我们还可以在一个GROUP BY语句中多次使用GROUPING SETS,如下:

  1. GROUP BY GROUPING SETS (A)  等价于  GROUP BY A,B,C
  2. ,GROUPING SETS (B)
  3. ,GROUPING SETS (C)
  4. GROUP BY GROUPING SETS (A)  等价于  GROUP BY A,B,C
  5. ,GROUPING SETS ((B,C))
  6. GROUP BY GROUPING SETS (A)  等价于  GROUP BY A,B
  7. ,GROUPING SETS (B,C)        UNION ALL
  8. GROUP BY A,C

我们还可以混合使用,如下:

  1. GROUP BY A                     等价于  GROUP BY A
  2. ,B                                     ,B
  3. ,GROUPING SETS ((B,C))                 ,C
  4. GROUP BY A                    等价于  GROUP BY A,B,C
  5. ,B                            UNION ALL
  6. ,GROUPING SETS (B,C)          GROUP BY A,B
  7. GROUP BY A                    等价于 GROUP BY A,B,C
  8. ,B                           UNION ALL
  9. ,C                           GROUP BY A,B,C
  10. ,GROUPING SETS (B,C)

请特别注意上面的第3条语句。

下面我们介绍一下ROLLUP和CUBE关键字,它们的使用方式类似,作用也类似,都是用来为GROUP BY语句返回的结果添加汇总信息,也可以说,它们是对分组结果进行二次分组。下面我们看一个简单的例子,如下:

  1. SELECT
  2. DEPT   AS 部门,
  3. SEX    AS 性别,
  4. AVG(SALARY) AS 平均工资
  5. FROM
  6. (
  7. --姓名  性别  部门  工资
  8. VALUES
  9. ('张三','男','市场部',4000),
  10. ('赵红','男','技术部',2000),
  11. ('李四','男','市场部',5000),
  12. ('李白','女','技术部',5000),
  13. ('王五','女','市场部',3000),
  14. ('王蓝','女','技术部',4000)
  15. ) AS EMPLOY(NAME,SEX,DEPT,SALARY)
  16. GROUP BY ROLLUP(DEPT,SEX)
  17. ORDER BY 部门,性别
  18. 查询结果:
  19. 部门          性别        平均工资
  20. 市场部         女          3000
  21. 市场部         男          4500
  22. 市场部         NULL        4000
  23. 技术部         女          4500
  24. 技术部         男          2000
  25. 技术部         NULL        3666
  26. NULL           NULL        3833

值得注意的是,上面的ROLLUP语句中,部门(DEPT)和性别(SEX)的顺序非常重要,如果我们互换一下它两的顺序,将得到不同的结果,如下:

  1. SELECT
  2. SEX    AS 性别,
  3. DEPT   AS 部门,
  4. AVG(SALARY) AS 平均工资
  5. FROM
  6. (
  7. --姓名  性别  部门  工资
  8. VALUES
  9. ('张三','男','市场部',4000),
  10. ('赵红','男','技术部',2000),
  11. ('李四','男','市场部',5000),
  12. ('李白','女','技术部',5000),
  13. ('王五','女','市场部',3000),
  14. ('王蓝','女','技术部',4000)
  15. ) AS EMPLOY(NAME,SEX,DEPT,SALARY)
  16. GROUP BY ROLLUP(SEX,DEPT)
  17. ORDER BY 性别,部门
  18. 查询结果:
  19. 性别         部门         平均工资
  20. 女         市场部         3000
  21. 女         技术部         4500
  22. 女         NULL           4000
  23. 男         市场部         4500
  24. 男         技术部         2000
  25. 男         NULL           3666
  26. NULL       NULL           3833

CUBE语句比ROLLUP语句返回更多的内容,以下是将上面语句的ROLLUP替换为CUBE后得到的结果:

  1. SELECT
  2. DEPT   AS 部门,
  3. SEX    AS 性别,
  4. AVG(SALARY) AS 平均工资
  5. FROM
  6. (
  7. --姓名  性别  部门  工资
  8. VALUES
  9. ('张三','男','市场部',4000),
  10. ('赵红','男','技术部',2000),
  11. ('李四','男','市场部',5000),
  12. ('李白','女','技术部',5000),
  13. ('王五','女','市场部',3000),
  14. ('王蓝','女','技术部',4000)
  15. ) AS EMPLOY(NAME,SEX,DEPT,SALARY)
  16. GROUP BY CUBE(DEPT,SEX)
  17. ORDER BY 部门,性别
  18. 查询结果:
  19. 部门         性别         平均工资
  20. 市场部         女         3000
  21. 市场部         男         4500
  22. 市场部         NULL       4000
  23. 技术部         女         4500
  24. 技术部         男         2000
  25. 技术部         NULL       3666
  26. NULL           女         4000
  27. NULL           男         3666
  28. NULL           NULL       3833

如果我们替换CUBE语句中部门(DEPT)和性别(SEX)的顺序,我们将会得到相同的结果。

----更多参见:DB2 SQL 精萃

----声明:转载请注明出处。

----last updated on 2010.1.15

----written by ShangBo on 2010.1.15

----end

GROUPING SETS、ROLLUP、CUBE的更多相关文章

  1. 转:GROUPING SETS、ROLLUP、CUBE

    转:http://blog.csdn.net/shangboerds/article/details/5193211 大家对GROUP BY应该比较熟悉,如果你感觉自己并不完全理解GROUP BY,那 ...

  2. SQL Server 之 GROUP BY、GROUPING SETS、ROLLUP、CUBE

    1.创建表 Staff CREATE TABLE [dbo].[Staff]( ,) NOT NULL, ) NULL, ) NULL, ) NULL, [Money] [int] NULL, [Cr ...

  3. (2.4)DDL增强功能-数据汇总grouping、rollup、cube

    参考:https://www.cnblogs.com/nikyxxx/archive/2012/11/27/2791001.html 1.rollup (1)rollup在group by 子句中使用 ...

  4. Group By 多个分组集小结 --GROUPING SETS,GROUP BY CUBE,GROUP BY ROLLUP,GROUPING(),GROUPING_ID()

    T-SQL 多个分组集共有三种 GROUPING SETS, CUBE, 以及ROLLUP, 其中 CUBE和ROLLUP可以当做是GROUPING SETS的简写版 示例数据库下载: http:// ...

  5. vue、rollup、sass、requirejs组成的vueManager

    近段时间本人一直在思考如何基于vue搭建一个中后端管理系统的通用基础前端解决方案.思考的主要问题点如下: 如何使各个子业务模块的按需加载 css预处理方案的选择 如何引入现代的前端工程思想,也就是工程 ...

  6. SQL 中GROUP BY 、ROLLUP、CUBE 关系和区别

    转自:http://www.cnblogs.com/dyufei/archive/2009/11/12/2573974.html 不言自明,看SQL就完全理解了,不需要过多解释,不错,分享之: ROL ...

  7. SQLSERVER中的ALL、PERCENT、CUBE关键字、ROLLUP关键字和GROUPING函数

    SQLSERVER中的ALL.PERCENT.CUBE关键字.ROLLUP关键字和GROUPING函数 先来创建一个测试表 USE [tempdb] GO )) GO INSERT INTO [#te ...

  8. Grouping Sets:CUBE和ROLLUP从句

    在上一篇文章里我讨论了SQL Server里Grouping Sets的功能.从文中的例子可以看到,通过简单定义需要的分组集是很容易进行各自分组.但如果像从所给的列集里想要有所有可能的分布——即所谓的 ...

  9. TSQL 分组集(Grouping Sets)

    分组集(Grouping Sets)是多个分组的并集,用于在一个查询中,按照不同的分组列对集合进行聚合运算,等价于对单个分组使用“union all”,计算多个结果集的并集.使用分组集的聚合查询,返回 ...

随机推荐

  1. ANDROID对文件的操作介绍

    1. Android遵循MVC设计思想: M(业务层):service V:视图(main.xml). C:Activity 2.使用文件如何对数据进行存储 Activity提供了openFileOu ...

  2. HTML静态网页的格式与布局(position:(fixed、absolute、relative)、分层、float(left、right))

    一.position:fixed 锁定位置(相对于浏览器的位置),例如有些网站的右下角的弹出窗口. 示例: 二.position:absolute 1.外层没有position:absolute(或r ...

  3. Add Two Numbers - C++链表操作

    题目意思很简单,两个链表分别表示两个数,将两个数相加的结果存入一个新的链表中. 思路同样很简单:两个链表如果一样长,对应位置相加,如果某一个链表多了,则根据加的结果有无进位继续处理,全部结束后要考虑会 ...

  4. POJ 2778 DNA Sequence(AC自动机+矩阵快速幂)

    题目链接:http://poj.org/problem?id=2778 题意:有m种DNA序列是有疾病的,问有多少种长度为n的DNA序列不包含任何一种有疾病的DNA序列.(仅含A,T,C,G四个字符) ...

  5. Eclipse 实现关键字自动补全功能 (转)

    一般默认情况下,Eclipse ,MyEclipse 的代码提示功能是比Microsoft Visual Studio的差很多的,主要是Eclipse ,MyEclipse本身有很多选项是默认关闭的, ...

  6. Java 网络编程(Elliotte Rusty Harold)

    最近看了本Java网络编程方面的书,系统化一下Java网络编程,主要内容如下: 1.网络基础篇 这里包括基础的网络概念/ 输入输出流BIO/ Internet地址/URI/URL/HTTP/URLCo ...

  7. 实时消息传输协议 RTMP(Real Time Messaging Protocol)

    实时消息传输协议(RTMP)最初是由 Macromedia 为互联网上 Flash player 和服务器之间传输音频.视频以及数据流而开发的一个私有协议.Adobe 收购 Macromedia 购以 ...

  8. C#文本文件读写

    算机在最初只支持ASCII编码,但是后来为了支持其他语言中的字符(比如汉字)以及一些特殊字符(比如€),就引入了Unicode字符集.基于Unicode字符集的编码方式有很多,比如UTF-.UTF-. ...

  9. 微信 php 获取ticket

    <?phpheader('content-type:text/html; charset=utf8');define('TOKEN', 'youtoken'); // TOKENdefine(' ...

  10. [LeetCode]题解(python):085-Maximal Rectangle

    题目来源: https://leetcode.com/problems/maximal-rectangle/ 题意分析: 给定一个二维的二进制矩阵,也就是只包括0 和 1的,找出只包括1的最大的矩阵的 ...