我有一个存储时间、heart_rate和player_id的表。我需要以某种方式获取过去五分钟的心率数据的平均值,并根据球员ID对每个平均值进行分组。
发布于 2015-06-10 03:51:11
另一种选择是使用DATEDIFF
SELECT AVG(heart_rate) AS heart_rate,
player_id
FROM tablename
WHERE DATEDIFF(MINUTE, time, GETDATE()) < 5
GROUP BY player_id发布于 2015-06-10 03:52:28
这在一定程度上是对Donal的回答的回应(评论太长了)。
您不希望使用以下内容:
WHERE datepart(minute, (time - GETDATE())) < 5有两个原因。首先,这不能使用time上的索引。也就是说,该计算是不可马赛尔的。其次,减法是向后的,除非time值是将来的。
更好的写法是:
select player_id, avg(heart_rate)
from table t
where time >= dateadd(minute, -5, getdate())
group by player_id;https://stackoverflow.com/questions/30741043
复制相似问题