我正在创建一个多租户应用程序,对于用户触发的特定事件,我将事件启动时间保存在数据库(SQLite)中。为了确定峰值请求时间,我试图找到保存的时间戳的模式。不要混淆平均,这将给我一个平均的所有时间戳-我正在寻找一种方法,以找到一个范围类似的结果,反映峰值。从下午2点到下午4点,大部分事件都被解雇了。时间戳以:NN:SS格式存储为字符串值。
我在写一个帮助解决这个问题的查询时遇到了问题。
发布于 2014-03-03 09:53:27
该算法应如下:
下面是一个示例查询,当范围持续时间为1小时时,您可以完成时间戳的查找模式:
SELECT Range AS RangeStart, Range+1 AS RangeEnd FROM
(
SELECT STRFTIME('%H',starttime) AS Range, COUNT(*) As cnt FROM Events
GROUP BY STRFTIME('%H',starttime)
)
ORDER BY cnt DESC
LIMIT 1;您可以在SQL Fiddle上检查代码
如果它能解决你的问题请告诉我。
发布于 2014-03-03 10:43:35
在SQLite中,您可以使用类似的查询来获取DATETIME的中值
SELECT DATETIME(CAST(AVG(CAST(strftime("%s",T) as int)) AS TEXT),'unixepoch') median FROM
(SELECT TEST T FROM TABLE1 ORDER BY TEST
LIMIT 2 - (SELECT COUNT(*) FROM TABLE1) % 2
OFFSET ((SELECT COUNT(*) FROM TABLE1) / 2) -
(1 - (SELECT COUNT(*) FROM TABLE1) % 2))T2;SQL Fiddle
发布于 2014-03-03 11:40:15
以下是我为解决这个问题所做的工作:-
https://stackoverflow.com/questions/22142446
复制相似问题