ROLLUP 运算符生成的结果集类似于 CUBE 运算符生成的结果集。

下面是 CUBE 和 ROLLUP 之间的具体区别:

  • CUBE 生成的结果集显示了所选列中值的所有组合的聚合。
  • ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。

    ROLLUP 优点:

    • (1)ROLLUP 返回单个结果集,而 COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性。
    • (2)ROLLUP 可以在服务器游标中使用,而 COMPUTE BY 则不可以。
    • (3)有时,查询优化器为 ROLLUP 生成的执行计划比为 COMPUTE BY 生成的更为高效。

下面对比一下GROUP BY 、CUBE 和  ROLLUP后的结果

创建表:

CREATE TABLE DEPART 
(部门 char(10),员工 char(6),工资 int)

INSERT INTO DEPART SELECT 'A','ZHANG',100 
INSERT INTO DEPART SELECT 'A','LI',200 
INSERT INTO DEPART SELECT 'A','WANG',300 
INSERT INTO DEPART SELECT 'A','ZHAO',400 
INSERT INTO DEPART SELECT 'A','DUAN',500 
INSERT INTO DEPART SELECT 'B','DUAN',600 
INSERT INTO DEPART SELECT 'B','DUAN',700

部门         员工         工资

A             ZHANG     100 
A             LI             200 
A             WANG      300 
A             ZHAO      400 
A             DUAN      500 
B             DUAN      600 
B             DUAN      700

(1)GROUP BY

SELECT 部门,员工,SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY 部门,员工

结果:

A             DUAN      500 
B             DUAN      1300 
A             LI        200 
A             WANG      300 
A             ZHANG     100 
A             ZHAO      400

(2)ROLLUP

SELECT 部门,员工,SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY  部门,员工  WITH ROLLUP

结果如下:

A             DUAN       500 
A             LI             200 
A             WANG      300 
A             ZHANG     100 
A             ZHAO       400 
A             NULL        1500 
B             DUAN       1300 
B             NULL       1300 
NULL       NULL        2800

ROLLUP结果集中多了三条汇总信息:即部门A的合计,部门B的合计以及总合计。其中将部门B中的DUAN合计。

等价于下列SQL语句

SELECT 部门,员工,SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY 部门,员工 
union 
SELECT 部门,'NULL',SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY  部门 
union 
SELECT 'NULL','NULL',SUM(工资)AS TOTAL 
FROM DEPART

结果:

A             DUAN      500 
A             LI           200 
A             NULL      1500 
A             WANG      300 
A             ZHANG     100 
A             ZHAO       400 
B             DUAN      1300 
B             NULL       1300 
NULL       NULL        2800

(3)CUBE

SELECT 部门,员工,SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY 部门,员工 WITH CUBE

结果:

A             DUAN      500 
A             LI           200 
A             WANG      300 
A             ZHANG     100 
A             ZHAO      400 
A             NULL      1500 
B             DUAN      1300 
B             NULL      1300 
NULL    NULL         2800 
NULL    DUAN        1800 
NULL    LI               200 
NULL    WANG       300 
NULL    ZHANG       100 
NULL    ZHAO         400

CUBE的结果集是在 ROLLUP结果集的基础上多了5行,这5行相当于在ROLLUP结果集上在union 上以员工 (即CUBE)为 GROUP BY的结果。

SELECT 部门,员工,SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY 部门,员工 WITH CUBE

等价于下列的SQL语句:

SELECT 部门,员工,SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY  部门,员工  WITH ROLLUP

union

SELECT 'NULL',员工,SUM(工资)AS TOTAL 
FROM DEPART 
GROUP BY 员工

结果:

NULL    NULL    2800 
A             NULL    1500 
A             DUAN      500 
A             LI        200 
A             WANG      300 
A             ZHANG     100 
A             ZHAO      400 
B             NULL    1300 
B             DUAN      1300 
NULL    DUAN      1800 
NULL    LI             200 
NULL    WANG      300 
NULL    ZHANG     100 
NULL    ZHAO      400

不用讲了吧,一对比结果就全明白了。

ROLLUP ( )

生成简单的 GROUP BY 聚合行以及小计行或超聚合行,还生成一个总计行。
 
SELECT a, b, c, SUM ( <expression> )
  FROM T
  GROUP BY ROLLUP (a,b,c);
   
 
会为 (a, b, c)、 (a, b) 和 (a) 值的每个唯一组合生成一个带有小计的行。 
还将计算一个总计行。
 
 
列是按照从右到左的顺序汇总的。
列的顺序会影响 ROLLUP 的输出分组,而且可能会影响结果集内的行数。
 
CUBE ( )
 
生成简单的 GROUP BY 聚合行、ROLLUP 超聚合行和交叉表格行。
   
SELECT a, b, c, SUM (<expression>)
FROM T
GROUP BY CUBE (a,b,c);
 
 
会为 (a, b, c)、 (a, b)、 (a, c)、 (b, c)、 (a)、 (b) 和 (c) 值的每个唯一组合生成一个带有小计的行,还会生成一个总计行。 
 
列的顺序不影响 CUBE 的输出。

SQL 中ROLLUP 用法的更多相关文章

  1. Sql 中Collate用法

    今天查询sqlite的时候需要不区分大小写,查了下文档,需要使用collate nocase.顺便学习下collate的用法. collate在sql中是用来定义排序规则的.排序规则其实就是当比较两个 ...

  2. sql 中 exists用法

    SQL中EXISTS的用法   比如在Northwind数据库中有一个查询为SELECT c.CustomerId,CompanyName FROM Customers cWHERE EXISTS(S ...

  3. 数据库sql中distinct用法注意事项

    在写sql中去重复等操作,需要用到distinct. 在使用distinct的时候要注意,尤其是在有行列转换的时候.要把sql运行出来看看是不是与你想要的结果一样. 通过自己试验,distinct有从 ...

  4. 详细的SQL中datediff用法

    DATEDIFF 函数 [日期和时间] 功能返回两个日期之间的间隔. 语法DATEDIFF ( date-part, date-expression-1, date-expression-2 ) da ...

  5. Sql中CHARINDEX用法

    CHARINDEX作用 写SQL语句我们经常需要判断一个字符串中是否包含另一个字符串,但是SQL SERVER中并没有像C#提供了Contains函数,不过SQL SERVER中提供了一个叫CHAEI ...

  6. SQL中ISNULL用法示例

    ISNULLSQL查询示例SELECT ISNULL    使用指定的替换值替换 NULL. 语法       :ISNULL ( check_expression , replacement_val ...

  7. sql中table用法

    for c in (select column_value from table(f_split(V_FileID, ','))) loop --若没有填写资格开始结束时间,则填入 select co ...

  8. SQL 中 HAVING 用法

    现在 Student表有 如下数据 现需求如下: 查找每个老师的学生的平均年龄且平均年齿大于12 不使用 HAVING SELECT * FROM (SELECT TeacherID, AVG(Age ...

  9. SQL中的between and

    "between xx and  xx "在SQL中的用法 这个大家都很熟悉,但是当问到是否包含两端的值时,就有点儿不确定了.在W3School网站上,有这样的一段话: 参考:ht ...

随机推荐

  1. 设置searchBar上右边取消按钮的颜色

    [[UIBarButtonItem appearanceWhenContainedIn: [UISearchBar class], nil] setTintColor:RGBA(0, 161, 176 ...

  2. C#: enum

    C#的枚举类型跟C++差不多,一般我们将enum设为单个状态,比如enum color_t { RED, BLACK, GREEN}, 只能选择一个 而有的时候枚举可以作为位运算来进行与或运算,比如C ...

  3. springday04-go2

    练习:计算一个人的bmi指数.算法如下: 身高 单位是米 比如1.70 体重 单位是公斤 比如90 bmi指数 = 体重/身高/身高 如果bmi>24过重,否则正常.视图需要两个,一个是bmi_ ...

  4. kafka迁移数据目录

    问题 先前存储kafka日志的磁盘空间太小,zabbix警报不断,于是加了磁盘,将日志存到新磁盘上. 解决方案 依次在每台机器上操作,保证有机器能响应producer和consumer的操作. 加磁盘 ...

  5. [tp3.2.1]sql查询语句(一)

    基本查询方式    字符串条件查询,    索引数组条件查询    对象条件查询    SQL语句大小写是一样的,但是,执行的时候有一个小写到大写的转换,所以最好写大写 $condition=new ...

  6. 运行eclipse提示 The requested resource () is not available.

    不识别web-inf目录,把文件放在Webcontent下就可以运行. 放在其他文件夹里也可以识别.

  7. 我的AutoCAD二次开发之路 (一)

    原帖地址 http://379910987.blog.163.com/blog/static/33523797201011184552167/ 今天在改代码的时候,遇到了AddVertexAt方法的用 ...

  8. COM编程之二 接口

    [1]接口 DLL的接口是它所输出的那些函数. C++类的接口是该类的一个成员函数集. COM接口是包含一个函数指针数组的内存结构. 每一个数组元素包含的是一个由组件所实现的函数的地址. 在COM中接 ...

  9. 在路由器 RT-AC68U 安装迅雷远程过程

    赶紧记录下,省得时间久了忘记.  步骤如下: 1.下载迅雷远程的 Linux 组件: http://pan.baidu.com/s/1jGqYPnw . 解压缩. 2.ssh 登录au68u 路由器 ...

  10. TI CC2541的整体目标

    1. App端会发送一定数量的byte过来蓝牙, 每2个byte是一个汉字的编码. 2. 拿到汉字编码之后, 统计字符数量, 然后通过SPI, 搜索编码 3. 收到的编码, 每个汉字字符有32个byt ...