我有下表。第一列是对象Id,然后是对象大小,最后是出售特定对象的时间。
Object Price Moment
A 100 2014-10-10 22:12:00
B 105 2014-10-10 22:12:44
A 100 2014-10-10 22:14:12
C 203 2014-10-10 22:15:02
B 105 2014-10-10 22:17:34
D 68 2014-10-10 22:42:01
C 203 2014-10-10 22:43:02通过使用下面的sql,我得到了每15分钟出售一次的所有对象的价格之和。
SELECT
Date(Moment) Date,
sec_to_time(time_to_sec(Moment) - time_to_sec(Moment)%(15*60)) 15MinInterval,
Sum(Price) PriceSum
FROM table
GROUP BY
Date,
15MinInterval
ORDER BY
Date,
15MinInterval这很好,我得到的结果是:
2014-10-10 22:00:00 305
2014-10-10 22:15:00 308
2014-10-10 22:30:00 271我所需要的,但我找不到办法去做,就是每15分钟计算一次所有不同物体的价格之和。因此,对于特定的表,我需要得到以下结果:
2014-10-10 22:00:00 205
2014-10-10 22:15:00 308
2014-10-10 22:30:00 271你能帮忙吗?
发布于 2014-10-11 01:20:24
尝试在子查询中使用DISTINCT
SQL Fiddle:http://sqlfiddle.com/#!2/fc040/9
SELECT
Date,
15Interval 15MinInterval,
Sum(Price) PriceSum
FROM
(SELECT DISTINCT
OBJECT,
Price,
Date(Moment) Date,
sec_to_time(time_to_sec(Moment) - time_to_sec(Moment)%(15*60)) AS 15Interval
FROM mytable) temp
GROUP BY
Date,
15MinInterval
ORDER BY
Date,
15MinInterval输出

https://stackoverflow.com/questions/26309899
复制相似问题