mysql聚合函数rollup和cube

转:https://blog.csdn.net/liuxiao723846/article/details/48970443

一、with rollup:

with rollup 通常和group by 语句一起使用,是根据维度在分组的结果集中进行聚合操作。——对group by的分组进行汇总。

 

假设用户需要对N个纬度进行聚合查询操作,普通的groupby语句需要N个查询和N次group by操作。而rollup的有点是一次可以去的N次groupby的结果,这样可以提高查询效率,同时大大减少网络的传输流量。

 

1、rollup演示:

 

1)创建表:

create table rollup(

orderid int not null,

orderdate date not null,

empid int not null,

custid varchar(10) not null,

qty int not null,

primary key(orderid,orderdate));

 

2)插入数据:

insert into rollup select 1,\'2010-01-02\',3,\'A\',10;

insert into rollup select 2,\'2010-04-02\',2,\'B\',20;

insert into rollup select 3,\'2010-05-02\',1,\'A\',30;

insert into rollup select 4,\'2010-07-02\',3,\'D\',40;

insert into rollup select 5,\'2011-01-02\',4,\'A\',20;

insert into rollup select 6,\'2011-01-02\',3,\'B\',30;

insert into rollup select 7,\'2011-01-02\',1,\'C\',40;

insert into rollup select 8,\'2009-01-02\',2,\'A\',10;

insert into rollup select 9,\'2009-01-02\',3,\'B\',20;

 

3)首先按照年份分组、统计销量;然后在对年份这一个纬度进行聚合

select year(orderdate) yearsum(qty) sum  from rollupgroup by yere(orderdate)

 

然后对年份进行聚合:

 

select year(orderdate) yearsum(qty) sum  from rollup

group by yere(orderdate) with rollup;

 

和普通的groupby差别不大,只是多了一个(null,220),表示对所有的year再做一次聚合,即订单数量总和。对单个唯独进行rollip操作只是可以在最后得到聚合的数据,对比groupby语句并没有非常大的优势。

 

4)对多个纬度进行聚合:

select empid,custidyear(orderdate) year,sum(qty) sum from rollup

group by empid,custid,year(orderdate)

with rollup;

 

 

对三次分组都进行了聚合,一个有三种聚合,其中:

  • (null,null,null)表示最后的聚合
  • (empid,null,null)表示仅对(empid)一列进行分组的聚合结果
  • (empid,custid,null)表示对(empid,custid)两列进行分组的聚合结果
  • (empid,custid,year)表示对这3列进行分组的聚合结果——也就是group by本身聚集

 

所以,上面结果等价于:(未排序)

select empid,custid,year(orderdate) year,sum(qty) sum from rollup

group by empid,custid,year(orderdate)

union

select empid,custid,null,sum(qty) sum from rollup

group by empid,custid

union

select empid,null,null,sum(qty) sum from rollup

group by empid

union

select null,null,null,sum(qty) sum from rollup

 

 

2、rollup注意:

1)ORDER BY不能在rollup中使用,两者为互斥关键字;

2)如果分组的列包含NULL值,那么rollup的结果可能不正确,因为在rollup中进行的分组统计时,null具有特殊意义。因此在进行rollup时可以先将

null转换成一个不可能存在的值,或者没有特别含义的值,比如:IFNULL(xxx,0)

3)mysql中没有像oracle那样的grouping()函数;

 

【实例】

selectifnull(dept,'总计') as '部门',ifnull(phone,'小计') as '电话',sum(money) as '金额' fromgroupTable group by 

    dept,phone with rollup;

+--------+------+------+

 | 部门  | 电话| 金额|

  +--------+------+------+

 | 财务部| 6001 |   10 |

  |财务部| 6003 |  100 |

  |财务部| 小计|  110 |

  |营业部| 8001 |   20 |

  |营业部| 8002 |   30 |

 | 营业部| 小计|   50 |

 | 总计  | 小计|  160 |

 +--------+------+------+


二、cube:

 

rollup是cube的一种特殊情况,和rollup一样,cube也是一种对数据的聚合操作。但是rollup只在层次上对数据进行聚合,而cube对所有的维度进行聚合。具有N个维度的列,cube需要2的N次方次分组操作,而rollup只需要N次分组操作

 

在mysql5.6.17版本中,只定义了cube,但是不支持cube操作。

 

2、rollup和cube的区别:

1)假设有n个维度,rollup会有n个聚合:

rollup(a,b)   统计列包含:(a,b)、(a)、()

rollup(a,b,c)统计列包含:(a,b,c)、(a,b)、(a)、()

……以此类推ing……

 

2)假设有n个纬度,cube会有2的n次方个聚合

cube(a,b)     统计列包含:(a,b)、(a)、(b)、()

cube(a,b,c)  统计列包含:(a,b,c)、(a,b)、(a,c)、(b,c)、(a)、(b)、(c)、()

……以此类推ing……

 

3、可以用rollup来模拟cube:

select 

    empid,custid,year(orderdate) year,sum(qty) sum from rollup

group by empid,custid,year(orderdate)

with rollup

union

select 

    empid,custid,year(orderdate) year,sum(qty) sum from rollup

group by empid,year(orderdate),custid

with rollup

union

select 

    empid,custid,year(orderdate) year,sum(qty) sum from rollup

group by custid,year(orderdate),empid

with rollup

union

select 

    empid,custid,year(orderdate) year,sum(qty) sum from rollup

group by custid,empid,year(orderdate)

with rollup

union

select 

    empid,custid,year(orderdate) year,sum(qty) sum from rollup

group by year(orderdate),empid,custid

with rollup

union

select 

    empid,custid,year(orderdate) year,sum(qty) sum from rollup

group by year(orderdate),empid,custid

with rollup;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/423558.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在C#里,如何执行cmd里的常用dos命令 (转)

http://blogger.org.cn/blog/more.asp?namenrzj&id4280 using System; using System.Diagnostics; namespace Tipo.Tools.Utility { /// <summary> /// 常用Dos命令操作 /// </summary> public class DosCommand { private Process processnull; pri…

Spring Boot----监控管理

用来监控spring 项目信息的 1、创建项目 1.1 启动项目 转载于:https://www.cnblogs.com/yanxiaoge/p/11400734.html

shiro学习(15):使用注解实现权限认证和后台管理

工具idea 先看看数据库 shiro_role_permission 数据 shiro_user shiro_user_role 数据 在pom.xml里面添加 <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3…

什么是索引?索引类型有几种,各有什么特点?

转发: 索引是对数据库表中一列或多列的值进行排序的一种结构&#xff0c;例如 employee 表的姓&#xff08;name&#xff09;列。如果要按姓查找特定职员&#xff0c;与必须搜索表中的所有行相比&#xff0c;索引会帮助您更快地获得该信息。 索引是一个单独的、物理的数据库结…

设置Netbeans 6.5为英文界面

进入netbeans 6.5/etc目录&#xff0c;编辑netbeans.conf文件&#xff0c;将其中的#command line switchs下面那行添加启动参数&#xff1a; -J-Duser.languagezh -J-Duser.countryUS变为&#xff1a;netbeans_default_options"-J-client -J-Xss2m -J-Xms32m -J-XX:PermSi…

用小程序·云开发打造功能全面的博客小程序丨实战

用小程序云开发将博客小程序常用功能“一网打尽” 本文介绍mini博客小程序的详情页的功能按钮如何实现&#xff0c;具体包括评论、点赞、收藏和海报功能&#xff0c;这里记录下整个实现过程和实际编码中的一些坑。 评论、点赞、收藏功能 实现思路 实现文章的一些操作功能&#…

shiro学习(16):使用注解实现权限认证和后台管理二

工具idea 先看看数据库 shiro_role_permission 数据 shiro_user shiro_user_role 数据 目录结构 在pom.xml里面添加 <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http…

Javascript玩转Prototype(一)——先谈C#原型模式

在《Javascript玩转继承&#xff08;二&#xff09;》中&#xff0c;我使用了原型继承法来实现Javascript的继承&#xff0c;那原型究竟奥秘何在。在这篇文章中&#xff0c;我就主要针对原型来展开讨论。 抛开Javascript&#xff0c;我们先来看我们熟悉的常规的面向对象语言。…

hive的row_number()、rank()和dense_rank()的区别以及具体使用

参考:https://blog.csdn.net/qq_20641565/article/details/52841345?locationNum5&fps1 2016年10月17日 20:05:21 阅读数&#xff1a;4931 row_number()、rank()和dense_rank()这三个是hive内置的分析函数&#xff0c;下面我们来看看他们的区别和具体的使用案例。 首先…

HDU 1176 免费馅饼 (动态规划、另类数塔)

免费馅饼 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 76293 Accepted Submission(s): 26722 Problem Description 都说天上不会掉馅饼&#xff0c;但有一天gameboy正走在回家的小径上&#xff0c;忽然天上掉…

shiro学习(17):easyui布局测试

工具sublime <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Document</title><link href"themes/black/easyui.css" rel"stylesheet" /><link href"themes…

细节差距

2008年过去的了&#xff0c;到现在还是没有空出时间来好好的来写下日志&#xff0c;不是自己没有时间而是自己知道可是由于自己的懒惰一直在推&#xff0c;导致的结果是所有需要做的时间一直在推。 人生路上也许很多时候你有很多的选择&#xff0c;在面临选择的时候怎么样作出选…

对比Oracle和Mysql在锁机制上的类似和差异点

转:https://blog.csdn.net/c332472988/article/details/52804078 InnoDB行锁实现方式 InnoDB行锁是通过给索引上的索引项加锁来实现的&#xff0c;这一点MySQL与Oracle不同&#xff0c;后者是通过在数据块中对相应数据行加锁来实现的。InnoDB这种行锁实现特点意味着&#xff1…

BUUOJ reverse 刮开有奖

刮开有奖 这是一个赌博程序&#xff0c;快去赚钱吧&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&…

正则表达式测试工具

这个工具最开始是年前写的&#xff0c;原文见如下地址&#xff1a;写了一个测试正则表达式的小工具 后来快过年的时候一直忙着给票贩子送钱去了&#xff0c;没有把它写完&#xff0c;今天抽空把一些细节的功能完成了一下&#xff0c;感兴趣的朋友可以下载试用&#xff1a;点击…

快速排序的原理以及Java代码

package com.asiainfo.test;import java.util.Arrays;import sun.misc.Sort;public class QKSORT {//基本思路是&#xff1a;选择一个值为key 一般是选择左边第一个为key//先是从右向左找到小于 key 的值 将此值与 key 进行交换&#xff0c;由于key 是一个标记先不用交换 &…

BUUOJ reverse 不一样的flag

不一样的flag 是不是做习惯了常规的逆向题目&#xff1f;试试这道题&#xff0c;看你在能不能在程序中找到真正的flag&#xff01;注意&#xff1a;flag并非是flag{XXX}形式&#xff0c;就是一个’字符串‘&#xff0c;考验眼力的时候到了&#xff01; 注意&#xff1a;得到的 …

shiro学习(18):使用注解实现权限认证和后台管理三

工具idea 先看看数据库 shiro_role_permission 数据 shiro_user shiro_user_role 数据 目录结构 在pom.xml里面添加 <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http…

摇篮与家园

今天你从你出生的医院回到家里&#xff0c;终于和爸爸妈妈团圆了。   说你"回"到家里&#xff0c;似不确切&#xff0c;因为你是第一次来到这个家。   不对&#xff0c;应该说&#xff0c;你来了&#xff0c;我们才第一次有了一个家。   孩子是使家成其为家的根…

Java中的锁分类

转:http://www.cnblogs.com/qifengshi/p/6831055.html 在读很多并发文章中&#xff0c;会提及各种各样锁如公平锁&#xff0c;乐观锁等等&#xff0c;这篇文章介绍各种锁的分类。介绍的内容如下&#xff1a; 公平锁/非公平锁可重入锁独享锁/共享锁互斥锁/读写锁乐观锁/悲观锁…