详解MySQL数据库累积聚合原理与用法实例分析

数据库 MySQL
今天主要介绍一下mysql累积聚合原理与用法。下面,我们一起来看看吧。

今天主要介绍一下mysql累积聚合原理与用法。下面,我们一起来看看吧~

[[311690]]

累积聚会

累积聚合为聚合从序列内第一个元素到当前元素的数据,如为每个员工返回每月开始到现在累积的订单数量和平均订单数量。

行号问题有两个解决方案,分别是为使用子查询和使用连接。子查询的方法通常比较直观,可读性强。但是在要求进行聚合时,子查询需要为每个聚合扫描一次数据,而连接方法通常只需要扫描一次就可以得到结果。

下面的查询使用连接来得到结果

  1. SELECTa.empid,a.ordermonth,a.qty AS thismonth,SUM(b.qty) AS total,CAST(AVG(b.qty) AS DECIMAL(5,2)) AS avgFROM emporders a  INNER JOIN emporders bON a.empid=b.empidAND b.ordermonth <= a.ordermonth  GROUP BY a.empid,a.ordermonth,a.qtyORDER BY a.empid,a.ordermonth 

如果只是查询2015年的累积订单,可以加上以where条件

  1. WHERE DATE_FORMAT(a.ordermonth,'%Y')='2015' AND DATE_FORMAT(b.ordermonth,'%Y')='2015' 

运行结果如下

详解mysql数据库累积聚合原理与用法实例分析

此外可能还需要筛选数据,例如只需要返回每个员工到达某一目标之前每月订单的情况。这里假设统计每个员工的合计订单数量达到1000之前的累积情况。

这里可以使用HAVING过滤器来完成查询

  1. SELECT a.empid, a.ordermonth,a.qty AS thismonth, SUM(b.qty) AS total, CAST(AVG(b.qty) AS DECIMAL(5,2)) AS avgFROM emporders aINNER JOIN emporders b  ON a.empid=b.empid  AND b.ordermonth <= a.ordermonthWHERE DATE_FORMAT(a.ordermonth,'%Y')='2015' AND DATE_FORMAT(b.ordermonth,'%Y')='2015'GROUP BY a.empid,a.ordermonth,a.qtyHAVING total<1000ORDER BY a.empid,a.ordermonth 

这里并没有统计到达到1000时该月的情况,如果要进行统计,则情况又有点复杂。如果指定了total <= 1000,则只有该月订单数量正好为1000才进行统计,否则不会对该月进行统计。因此这个问题的过滤,可以从另外一个方面来考虑。当累积累积订单小于1000时,累积订单与上个月的订单之差是小于1000的,同时也能对第一个订单数量超过1000的月份进行统计。故该解决方案的SQL语句如下

  1. SELECT a.empid, a.ordermonth,a.qty AS thismonth, SUM(b.qty) AS total, CAST(AVG(b.qty) AS DECIMAL(5,2)) AS avgFROM emporders aINNER JOIN emporders b  ON a.empid=b.empid  AND b.ordermonth <= a.ordermonthWHERE DATE_FORMAT(a.ordermonth,'%Y')='2015' AND DATE_FORMAT(b.ordermonth,'%Y')='2015'GROUP BY a.empid,a.ordermonth,a.qtyHAVING total-a.qty < 1000ORDER BY a.empid,a.ordermonth 

运行结果如下

详解mysql数据库累积聚合原理与用法实例分析

如果只想返回达到累积订单数为1000的当月数据,不返回之前的月份,则可以对上述SQL语句

进一步过滤,再添加累积订单数量大于等于1000的条件。该问题的SQL语句如下,

  1. SELECT a.empid, a.ordermonth,a.qty AS thismonth, SUM(b.qty) AS total, CAST(AVG(b.qty) AS DECIMAL(5,2)) AS avgFROM emporders aINNER JOIN emporders b  ON a.empid=b.empid  AND b.ordermonth <= a.ordermonthWHERE DATE_FORMAT(a.ordermonth,'%Y')='2015' AND DATE_FORMAT(b.ordermonth,'%Y')='2015'GROUP BY a.empid,a.ordermonth,a.qtyHAVING total-a.qty < 1000 AND total >= 1000ORDER BY a.empid,a.ordermonth 

运行结果如下

详解mysql数据库累积聚合原理与用法实例分析

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2009-12-31 11:10:01

2010-06-02 11:34:23

MySQL 数据库导入

2010-04-01 09:45:38

NoSQL

2011-05-19 13:25:14

Oracle数据库

2021-02-17 13:52:35

数据库group byMySQL

2019-07-17 10:19:36

MySQL数据库SQL

2009-09-07 15:25:24

MySQL数据库互操作Silverlight

2010-06-04 10:40:55

AJAX MySQL

2011-03-29 10:47:49

ORACLE数据库

2011-06-21 15:11:04

QT 数据库

2010-03-10 11:29:47

MySQL数据库性能调

2009-07-28 14:16:31

ASP.NET与MyS

2010-06-01 14:42:55

连接MySQL数据库

2011-07-26 18:11:56

iPhone Sqlite 数据库

2011-08-11 16:55:34

Oracle数据库AWR

2011-07-05 10:16:16

Qt 数据库 SQLite

2010-03-29 10:19:24

2022-03-29 10:52:08

MySQL数据库

2010-05-12 18:41:34

MySQL数据库

2010-06-09 17:36:45

MySQL数据库同步
点赞
收藏

51CTO技术栈公众号