rollup 和 cube 的区别
来源:互联网 发布:淘宝发展的起源 编辑:程序博客网 时间:2024/06/04 18:39
select 列1,sum(计算列) from table_name t group by rollup(列1,列2..列n);
会返回 【列1】 【列1,列2】【列1,列2,列3】...【列1,列2,列3...列n】的每种排列的sum(计算列) 和 全部记录的sum(计算列) ,一共是n+1种排列
select 列1,...列n,sum(计算列) from table_name t group by cube(列1,列2...列n);
会返回 【列1】,【列2】,【列3】,【列4】...【列n】,【列1,列2】,【列1,列3】,【列1,列4】...【列1,列n】,【列2,列3】,【列2,列4】...【列2,列n】...【列n-1,列n】 每个分组的sum(计算列) 和 全部记录的sum(计算列),一共是 C 0 n+C 1 n+C 2 n+...C n n种排列。
如下演示(因为多条数据会比较杂乱,不易说明,所以我们选择极端情况,就认为表里只有一条记录):
--group by
select flag1, flag2, flag3, flag4, sum(flag5)
from (select 'column1' as flag1,
'column2' as flag2,
'column3' as flag3,
'column4' as flag4,
1 flag5
from dual)
group by flag1, flag2, flag3, flag4;
from (select 'column1' as flag1,
'column2' as flag2,
'column3' as flag3,
'column4' as flag4,
1 flag5
from dual)
group by flag1, flag2, flag3, flag4;
--group by cobe
select flag1, flag2, flag3, flag4, sum(flag5)
from (select 'column1' as flag1,
'column2' as flag2,
'column3' as flag3,
'column4' as flag4,
1 flag5
from dual)
group by cube(flag1, flag2, flag3, flag4);
from (select 'column1' as flag1,
'column2' as flag2,
'column3' as flag3,
'column4' as flag4,
1 flag5
from dual)
group by cube(flag1, flag2, flag3, flag4);
--group by rollup
select flag1, flag2, flag3, flag4, sum(flag5)
from (select 'column1' as flag1,
'column2' as flag2,
'column3' as flag3,
'column4' as flag4,
1 flag5
from dual)
group by rollup(flag1, flag2, flag3, flag4);
from (select 'column1' as flag1,
'column2' as flag2,
'column3' as flag3,
'column4' as flag4,
1 flag5
from dual)
group by rollup(flag1, flag2, flag3, flag4);
rollup的分组排列种类为 n+1 ,上述例子group by 为4列,所以 是 4+1 种情况
cube的分组排列种类是 C 0 n+C 1 n+C 2 n+...C n n 上述例子group by 为4列,所以是C 0 4+C 1 4+C 2 4+C 3 4+C 4 4=1+4+6+4+1=16种情况
上面两种计算都是计算排列种类,并非是行数,行数由具体被分组的该列的值所确定的,这个虽然可以计算,但是比较麻烦也无意义,所以我的理解cube和rollup其实相当于对group 的多列字段进行排列,然后将每种排列进行展示或者进行聚合计算。
0 0
- rollup 和 cube 的区别
- CUBE 和 ROLLUP 之间的具体区别
- CUBE 和 ROLLUP 之间的具体区别
- CUBE 和 ROLLUP 之间的具体区别
- CUBE 和 ROLLUP 之间的具体区别
- CUBE 和 ROLLUP 之间的具体区别
- CUBE 和 ROLLUP 之间的具体区别
- Oracle rollup和cube区别
- MySQL ROLLUP和CUBE区别
- rollup和cube函数区别
- Rollup 和 Cube 的学习心得
- rollup和cube的妙用
- cube和rollup的用法
- group、grouping、rollup、cube的用法和区别
- group、grouping、rollup、cube的用法和区别
- 【转帖】with rollup和with cube的区别
- SQL ---CUBE 和 ROLLUP 之间的具体区别
- SQL 中ROLLUP、CUBE的用法和区别
- 温度与压强
- 高性能的分布式内存对象缓存系统Memcached
- 部分SWAP 内存知识
- php面试题与答案
- Android 4.4NotificationManagerService使用详解与原理分析(一)__使用详解
- rollup 和 cube 的区别
- 实现图片的异步加载
- 脚本实现重新对一个磁盘分区格式化
- Leetcode-357- Count Numbers with Unique Digits C#
- Android 开发技巧-Listview通用适配器BaseCommAdapter
- Java 中 Number那些事
- ibatis如何返回存储过程中的输出参数
- 开放平台-web实现QQ第三方登录
- MySQL delete/truncate/drop的差别分析