转:http://blog.csdn.net/shangboerds/article/details/5193211

大家对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)的顺序,我们将会得到相同的结果

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

  1. SQL GROUP BY GROUPING SETS,ROLLUP,CUBE(需求举例)

    实现按照不同级别分组统计 关于GROUP BY 中的GROUPING SETS,ROLLUP,CUBE 从需求的角度理解会更加容易些. 需求举例: 假如一所学校只有两个系, 每个系有两个专业, 每个专 ...

  2. GROUPING SETS、CUBE、ROLLUP

    其实还是写一个Demo 比较好 USE tempdb IF OBJECT_ID( 'dbo.T1' , 'U' )IS NOT NULL BEGIN DROP TABLE dbo.T1; END; G ...

  3. Hive函数:GROUPING SETS,GROUPING__ID,CUBE,ROLLUP

    参考:lxw大数据田地:http://lxw1234.com/archives/2015/04/193.htm 数据准备: CREATE EXTERNAL TABLE test_data ( mont ...

  4. Hive高级聚合GROUPING SETS,ROLLUP以及CUBE

    scala> import org.apache.spark.sql.hive.HiveContextimport org.apache.spark.sql.hive.HiveContext s ...

  5. Hive高阶聚合函数 GROUPING SETS、Cube、Rollup

    -- GROUPING SETS作为GROUP BY的子句,允许开发人员在GROUP BY语句后面指定多个统计选项,可以简单理解为多条group by语句通过union all把查询结果聚合起来结合起 ...

  6. SQL Server2008 程序设计 汇总 GROUP BY,WITH ROLLUP,WITH CUBE,GROUPING SETS(..)

    --SQL Server2008 程序设计 汇总 GROUP BY ,WITH ROLLUP  WITH CUBE  GROUPING SET(..) /*********************** ...

  7. Hive学习之路 (十七)Hive分析窗口函数(五) GROUPING SETS、GROUPING__ID、CUBE和ROLLUP

    概述 GROUPING SETS,GROUPING__ID,CUBE,ROLLUP 这几个分析函数通常用于OLAP中,不能累加,而且需要根据不同维度上钻和下钻的指标统计,比如,分小时.天.月的UV数. ...

  8. TSQL 分组集(Grouping Sets)

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

  9. Hive SQL grouping sets 用法

    概述 GROUPING SETS,GROUPING__ID,CUBE,ROLLUP 这几个分析函数通常用于OLAP中,不能累加,而且需要根据不同维度上钻和下钻的指标统计,比如,分小时.天.月的UV数. ...

随机推荐

  1. 8-JS闭包、回调实例

    1.回调 javascipt中,函数回调一般用于以下几种场景: 1.异步执行(例如读取文件,进行HTTP请求) 2.同步(阻塞) 3.事件监听和处理 4.设置超时和时间间隔的方法 异步例子(使用AJA ...

  2. mysql多表查询例子

    [理解方式]先分别找出每个表中查询出来的结果,然后再将两个结果合并. create database test charset utf8 collate utf8_bin;use test;creat ...

  3. Javascript学习笔记:6种实现继承的方式

    ①原型链式继承 function Person(name){ this.name=name; } Person.prototype.getName=function(){ return this.na ...

  4. Unicode 与(UTF-8,UTF-16,UTF-32,UCS-2)

    Unicode是什么? Unicode源于一个很简单的想法:将全世界所有的字符包含在一个集合里,计算机只要支持这一个字符集,就能显示所有的字符,再也不会有乱码了. U+597D = 好 597D 是1 ...

  5. collectionView布局原理及瀑布流布局方式

    一直以来都想研究瀑布流的具体实现方法(起因是因为一则男女程序员应聘的笑话,做程序的朋友应该都知道).最近学习到了瀑布流的实现方法,瀑布流的实现方式有多种,这里应用collectionView来重写其U ...

  6. mac 安装tomcat

    一.下载 首先在tomcat官网下载完整版的 tomcat.tar.gz包,Core下 注: zip用于windows操作系统,tar.gz用于unix和linux操作系统. Binary Distr ...

  7. Android 检查手机网络是否可用

    添加网络状态权限 <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> 代 ...

  8. 安装eclipse插件时出现问题

    有时候我们安装eclipse插件时,会无法找到repository,这个时候去除掉多余的包,可能就行了.以下例子是安装spring插件,如果全选的话无法安装所有的插件,最终会失败 2.这时我们可以去掉 ...

  9. [SoapUI] JDBC 请求连接SQL Sever,MySQL

    MySQLDriver: com.mysql.jdbc.DriverConnection string: jdbc:mysql://localhost:3306/xxx?user=xxx&pa ...

  10. Android 通知栏Notification的整合 全面学习 (一个DEMO让你完全了解它)

    在android的应用层中,涉及到很多应用框架,例如:Service框架,Activity管理机制,Broadcast机制,对话框框架,标题栏框架,状态栏框架,通知机制,ActionBar框架等等. ...