ROLLUP和CUBE [转帖]_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3209 | 回复: 0   主题: ROLLUP和CUBE [转帖]        下一篇 
wayne
注册用户
等级:中校
经验:1690
发帖:221
精华:0
注册:2011-7-21
状态:离线
发送短消息息给wayne 加好友    发送短消息息给wayne 发消息
发表于: IP:您无权察看 2011-8-16 16:41:04 | [全部帖] [楼主帖] 楼主

Oracle的GROUP BY语句除了最基本的语法外,还支持ROLLUP和CUBE语句。

SQL> create table t as select * from dba_indexes;


表已创建。

SQL> select index_type, status, count(*) from t group by index_type, status;
INDEX_TYPE                  STATUS     COUNT(*)
--------------------------- -------- ----------
LOB                         VALID            51
NORMAL                      N/A              25
NORMAL                      VALID           479
CLUSTER                     VALID            11


下面来看看ROLLUP和CUBE语句的执行结果。

SQL> select index_type, status, count(*) from t group by rollup(index_type, status);
INDEX_TYPE                  STATUS     COUNT(*)
--------------------------- -------- ----------
LOB                         VALID            51
LOB                                          51
NORMAL                      N/A              25
NORMAL                      VALID           479
NORMAL                                      504
CLUSTER                     VALID            11
CLUSTER                                      11
566


已选择8行。

SQL> select index_type, status, count(*) from t group by cube(index_type, status);
INDEX_TYPE                  STATUS     COUNT(*)
--------------------------- -------- ----------
566
N/A              25
VALID           541
LOB                                          51
LOB                         VALID            51
NORMAL                                      504
NORMAL                      N/A              25
NORMAL                      VALID           479
CLUSTER                                      11
CLUSTER                     VALID            11


已选择10行。

查询结果不是很一目了然,下面通过Oracle提供的函数GROUPING来整理一下查询结果。

SQL> select grouping(index_type) g_ind, grouping(status) g_st, index_type, status, count(*)
2  from t group by rollup(index_type, status) order by 1, 2;
G_IND       G_ST INDEX_TYPE                  STATUS     COUNT(*)
---------- ---------- --------------------------- -------- ----------
0          0 LOB                         VALID            51
0          0 NORMAL                      N/A              25
0          0 NORMAL                      VALID           479
0          0 CLUSTER                     VALID            11
0          1 LOB                                          51
0          1 NORMAL                                      504
0          1 CLUSTER                                      11
1          1                                             566


已选择8行。

这个查询结果就直观多了,和不带ROLLUP语句的GROUP BY相比,ROLLUP增加了对INDEX_TYPE的GROUP BY统计和对所有记录的GROUP BY统计。

也就是说,如果是ROLLUP(A, B, C)的话,首先会对(A、B、C)进行GROUP BY,然后对(A、B)进行GROUP BY,然后是(A)进行GROUP BY,最后对全表进行GROUP BY操作。

下面看看CUBE语句。

SQL> select grouping(index_type) g_ind, grouping(status) g_st, index_type, status, count(*)
2  from t group by cube(index_type, status) order by 1, 2;
G_IND       G_ST INDEX_TYPE                  STATUS     COUNT(*)
---------- ---------- --------------------------- -------- ----------
0          0 LOB                         VALID            51
0          0 NORMAL                      N/A              25
0          0 NORMAL                      VALID           479
0          0 CLUSTER                     VALID            11
0          1 LOB                                          51
0          1 NORMAL                                      504
0          1 CLUSTER                                      11
1          0                             N/A              25
1          0                             VALID           541
1          1                                             566


已选择10行。

和ROLLUP相比,CUBE又增加了对STATUS列的GROUP BY统计。

如果是GROUP BY CUBE(A, B, C),则首先会对(A、B、C)进行GROUP BY,然后依次是(A、B),(A、C),(A),(B、C),(B),(C),最后对全表进行GROUP BY操作。

除了使用GROUPING函数,还可以使用GROUPING_ID来标识GROUP BY结果。

SQL> select grouping_id(index_type, status) g_ind, index_type, status, count(*)
2  from t group by rollup(index_type, status) order by 1;
G_IND INDEX_TYPE                  STATUS     COUNT(*)
---------- --------------------------- -------- ----------
0 LOB                         VALID            51
0 NORMAL                      N/A              25
0 NORMAL                      VALID           479
0 CLUSTER                     VALID            11
1 LOB                                          51
1 NORMAL                                      504
1 CLUSTER                                      11
3                                             566


已选择8行。

SQL> select grouping_id(index_type, status) g_ind, index_type, status, count(*)
2  from t group by cube(index_type, status) order by 1;
G_IND INDEX_TYPE                  STATUS     COUNT(*)
---------- --------------------------- -------- ----------
0 LOB                         VALID            51
0 NORMAL                      N/A              25
0 NORMAL                      VALID           479
0 CLUSTER                     VALID            11
1 LOB                                          51
1 NORMAL                                      504
1 CLUSTER                                      11
2                             N/A              25
2                             VALID           541
3                                             566


已选择10行。




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论