首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何计算SQL数据库中最近5分钟条目的平均值?

如何计算SQL数据库中最近5分钟条目的平均值?
EN

Stack Overflow用户
提问于 2015-06-10 03:23:57
回答 2查看 625关注 0票数 0

我有一个存储时间、heart_rate和player_id的表。我需要以某种方式获取过去五分钟的心率数据的平均值,并根据球员ID对每个平均值进行分组。

EN

回答 2

Stack Overflow用户

发布于 2015-06-10 03:51:11

另一种选择是使用DATEDIFF

代码语言:javascript
复制
SELECT  AVG(heart_rate) AS heart_rate,
        player_id
FROM    tablename
WHERE   DATEDIFF(MINUTE, time, GETDATE()) < 5
GROUP BY player_id
票数 3
EN

Stack Overflow用户

发布于 2015-06-10 03:52:28

这在一定程度上是对Donal的回答的回应(评论太长了)。

您不希望使用以下内容:

代码语言:javascript
复制
WHERE datepart(minute, (time - GETDATE())) < 5

有两个原因。首先,这不能使用time上的索引。也就是说,该计算是不可马赛尔的。其次,减法是向后的,除非time值是将来的。

更好的写法是:

代码语言:javascript
复制
select player_id, avg(heart_rate)
from table t
where time >= dateadd(minute, -5, getdate())
group by player_id;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30741043

复制
相关文章

相似问题

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