MySQL数据摘要技巧 – 是否有UNGROUP BY?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL数据摘要技巧 – 是否有UNGROUP BY?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2988字,纯文字阅读大概需要5分钟。
内容图文
![MySQL数据摘要技巧 – 是否有UNGROUP BY?](/upload/InfoBanner/zyjiaocheng/905/8a3065963a6342f7a78a5f78f4286145.jpg)
我正在尝试做一些数据报告,并且不经常做SQL体操以了解我正在寻找什么功能.我称之为“ungroup by”.我有一个SELECT输出,反映了一系列每月订阅项目:创建,关闭以及每月支出的金额:
+----+---------------------------------+------------+------------+------------+
| id | description | created_on | closed_on | monthly |
+----+---------------------------------+------------+------------+------------+
| 3 | Daily horoscope email | 2012-01-01 | null | 10000.0000 |
| 5 | Pet food delivery | 2012-01-05 | null | 3500.0000 |
| 6 | Dirty magazine subscription | 2012-01-09 | null | 1500.0000 |
| 7 | Stupid nuts posted in a box | 2012-01-01 | 2012-01-04 | 1500.0000 |
.... etc ...
我想要做的就是每天计算出“运行率”.因此,每天都会列出当前每月承诺的总计,即上述数据将映射到:
+------------+----------+
| date | run_rate |
+------------+----------+
| 2012-01-01 | 11500 |
| 2012-01-02 | 11500 |
| 2012-01-03 | 11500 |
| 2012-01-04 | 10000 |
| 2012-01-05 | 13500 |
| 2012-01-06 | 13500 |
| 2012-01-07 | 13500 |
| 2012-01-08 | 13500 |
| 2012-01-09 | 15000 |
我认为可能是每天创建一行一行的临时表,然后写一个LEFT JOIN / GROUP BY语句引用第一个表来构建我的输出.但我只能看到如何以这种方式创建日常“差异”,而不是运行总计,我需要将第一个表“取消组合”为两个条目,这是创建订阅时的正面条目,以及关闭时的否定条目.
我想坚持使用MySQL,如果可能的话,还要坚持使用一个超级声明.如果那是不可能的,我可以在我的查询框架中添加一些存储过程或临时表.或者我真的必须通过Ruby研磨我的数据? (我确切知道如何,但希望我能将所有逻辑保存在一个地方,并且我正在努力改进我们当前使用ActiveRecord的慢速计算).
解决方法:
以下是另一种使用它的方法:INFORMATION_SCHEMA.COLLATION_CHARACTER_SET_APPLICABILITY,它将在创建临时表的过程中创建日期,而不必创建临时表.解释计划可以确认哪种方法最适合您.
SET @rrate:= 0;
SELECT X.rdate, (@rrate:=@rrate +
COALESCE(Y.summonthly,0) -
COALESCE(Z.summonthly,0)) as run_rate
FROM(
SELECT date_add(P.createdon, interval `day` day)
as rdate
FROM
(SELECT @i:= @i + 1 AS `day`
FROM
INFORMATION_SCHEMA.COLLATION_CHARACTER_SET_APPLICABILITY,
(SELECT @i:= -1) AS i
) As D,
rategroups P
GROUP BY rdate
HAVING rdate <= (SELECT MAX(createdon) FROM rategroups)
ORDER BY rdate) X
LEFT JOIN
(SELECT createdon, sum(monthly) summonthly
FROM rategroups
GROUP BY createdon) Y
ON X.rdate = Y.createdon
LEFT JOIN
(SELECT closed_on, sum(monthly) summonthly
FROM rategroups
GROUP BY closed_on) Z
ON X.rdate = Z.closed_on
GROUP BY X.rdate
;
| RDATE | RUN_RATE |
---------------------------------------------
| January, 01 2012 00:00:00+0000 | 11500 |
| January, 02 2012 00:00:00+0000 | 11500 |
| January, 03 2012 00:00:00+0000 | 11500 |
| January, 04 2012 00:00:00+0000 | 10000 |
| January, 05 2012 00:00:00+0000 | 13500 |
| January, 06 2012 00:00:00+0000 | 13500 |
| January, 07 2012 00:00:00+0000 | 13500 |
| January, 08 2012 00:00:00+0000 | 13500 |
| January, 09 2012 00:00:00+0000 | 15000 |
内容总结
以上是互联网集市为您收集整理的MySQL数据摘要技巧 – 是否有UNGROUP BY?全部内容,希望文章能够帮你解决MySQL数据摘要技巧 – 是否有UNGROUP BY?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。