首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >时间列计算模式

时间列计算模式
EN

Stack Overflow用户
提问于 2014-03-03 09:02:52
回答 3查看 160关注 0票数 0

我正在创建一个多租户应用程序,对于用户触发的特定事件,我将事件启动时间保存在数据库(SQLite)中。为了确定峰值请求时间,我试图找到保存的时间戳的模式。不要混淆平均,这将给我一个平均的所有时间戳-我正在寻找一种方法,以找到一个范围类似的结果,反映峰值。从下午2点到下午4点,大部分事件都被解雇了。时间戳以:NN:SS格式存储为字符串值。

我在写一个帮助解决这个问题的查询时遇到了问题。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-03-03 09:53:27

该算法应如下:

  1. 选择范围的持续时间,例如1小时或2小时
  2. 对于每个时间戳,确定它属于哪个范围。例如,如果您选择了1小时范围,而时间戳是5:09 pm,那么它属于5:00 pm-6:00 pm范围。
  3. 按范围分组,并计算每个时间范围内的时间戳数量。
  4. 选择最大时间范围

下面是一个示例查询,当范围持续时间为1小时时,您可以完成时间戳的查找模式:

代码语言:javascript
复制
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上检查代码

如果它能解决你的问题请告诉我。

票数 1
EN

Stack Overflow用户

发布于 2014-03-03 10:43:35

SQLite中,您可以使用类似的查询来获取DATETIME的中值

代码语言:javascript
复制
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

票数 1
EN

Stack Overflow用户

发布于 2014-03-03 11:40:15

以下是我为解决这个问题所做的工作:-

  1. 我创建了另一个列,它只存储时间戳的时间。
  2. 运行以下查询。 选择EventHour,计数(*)作为CountOfHours从EventTable组按EventHour顺序由CountOfHours DESC限制1
  3. 这给出了活动的高峰交通时间的范围。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22142446

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档