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,一经查实,立即删除!

相关文章

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…

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

用小程序云开发将博客小程序常用功能“一网打尽” 本文介绍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;我们先来看我们熟悉的常规的面向对象语言。…

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…

正则表达式测试工具

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

shiro学习(19): 拦截器

1 拦截器介绍 Shiro使用了与Servlet一样的Filter接口进行扩展&#xff1b;所以如果对Filter不熟悉可以参考《Servlet3.1规范》http://www.iteye.com/blogs/subjects/Servlet-3-1了解Filter的工作原理。首先下图是Shiro拦截器的基础类图&#xff1a; 1、NameableFilter Name…

关于云开发新服务“实时数据推送”,你需要了解的全在这了!

“微信小程序工程师邓坤力带你了解如何利用千呼万唤始出来的云开发实时数据推送服务打造生动的小程序和小游戏&#xff01;” 在数据库在小程序云开发中的应用一文中&#xff0c;我们了解到实时数据推送作为云开发即将上线的一项新能力&#xff0c;主要指客户端使用官方SDK发起…

java实现二分查找-两种方式

转:https://blog.csdn.net/maoyuanming0806/article/details/78176957 二分查找是一种查询效率非常高的查找算法。又称折半查找。 起初在数据结构中学习递归时实现二分查找&#xff0c;实际上不用递归也可以实现&#xff0c;毕竟递归是需要开辟额外的空间的来辅助查询。本文就…

shiro学习(20): 自定义过滤规则

工具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…

css 一些 常用布局

div骨架 Code<div id"header">ss</div> <div id"container"> <div id"content">ss</div> <div id"side">ss</div> </div> <div id"pagefooter"…

shiro学习(21):动态添加验证规则1

工具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…

shiro学习(22):动态添加验证规则2

工具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…

shiro学习(23):动态添加验证规则3

工具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…

借助实时数据推送快速制作在线对战五子棋小游戏丨实战

1 项目概述 游戏开发&#xff0c;尤其是微信小游戏开发&#xff0c;是最近几年比较热门的话题。 本次「云开发」公开课&#xff0c;将通过实战「在线对战五子棋」&#xff0c;一步步带领大家&#xff0c;在不借助后端的情况下&#xff0c;利用「小程序 ✖ 云开发」&#xff0c;…

关于时间复杂度和空间复杂度的计算

转:https://blog.csdn.net/mr_garfield__/article/details/78762478 时间复杂度&#xff1a; 一般情况下&#xff0c;算法中基本操作重复的次数就是问题规模n的某个函数f&#xff08;n&#xff09;&#xff0c;进而分析f&#xff08;n&#xff09;随n的变化情况并确定T&#…

shiro学习(24):Spring的transaction-manager的用法

<?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xmlns:tx"http://www.springframework.org/sche…