博客
关于我
mysql连续聚合
阅读量:407 次
发布时间:2019-03-06

本文共 859 字,大约阅读时间需要 2 分钟。

连续聚合是按时间顺序对有序数据进行聚合的操作。

在下面的救示例中将使用EmpOrders表,该表用于存放每位员工每月发生的订购数量。
运行如下 代码创建EmpOrders表并填充示例数据。
CREATE TABLE EmpOrders (empid INT NOT NULL,ordermonth DATE NOT NULL,qty INT NOT NULL,testPRIMARY KEY (empid,ordermonth));
查询order表和orderdetails表住EmpOrder表插入每个月的订单,sql语句如下(技巧是根据月分组)
INSERT INTO EmpOrders SELECT a.employeeid,orderdate AS Order date,SUM(quantity) AS qty FROM orders aINNER JOIN orderdetails bON a.orderid=b.orderidGROUP BY employid,DATE_FORMAT(orderdate,'%Y-m');

下面给出生成示例数据的php文件

';$insert_sql = '';for($empid=1;$empid<=8;$empid++){ for($year=2009;$year<=2015;$year++) { for($month=1;$month<=12;$month++) { $num = rand(20,800); $insert_sql .= sprintf($sql,$empid,$year,$month,$num); } $insert_sql .= '
'; }}echo $insert_sql;
以下是员工订单表EmpOrder部分数据
下面根据EmpOrders表讨论3个连续聚合的问题:累积、滑动、年初至今。

转载地址:http://wclkz.baihongyu.com/

你可能感兴趣的文章
隐藏Nginx软件版本号信息
查看>>
httpd: apr_sockaddr_info_get() failed for bogon
查看>>
OAuth2.0认证详解
查看>>
如何禁用控制台窗口的关闭按钮?
查看>>
004.Kickstart部署之FTP架构
查看>>
001. Ansible简介
查看>>
006.SQLServer AlwaysOn可用性组高可用部署
查看>>
001.FTP简介及相关文件
查看>>
004.LVM缩减
查看>>
Maven构建命令相关
查看>>
Windows下chm转换为html的超简单方法
查看>>
Unknown character set: 'utf8mb4'
查看>>
《SpringCloud实战项目》系列目录
查看>>
div居中
查看>>
【Discuz】关闭QQ互联插件提示信息:系统繁忙,请稍后再试
查看>>
Netflix是什么,与Spring Cloud有什么关系
查看>>
秒懂JVM的三大参数类型,就靠这十个小实验了
查看>>
PHP内核之旅-3.变量
查看>>
干货 | 45张图庖丁解牛18种Queue,你知道几种?
查看>>
SpringBoot中的自动代码生成 - 基于Mybatis-Plus
查看>>