如何在MySQL中计算两个日期之间的平均值?我对时间值、小时和分钟更感兴趣。
在一张桌子上:
| date_one | datetime |
| date_two | datetime |
执行如下查询:
SELECT AVG(date_one-date_two) FROM some_table WHERE some-restriction-applies;
编辑:
AVG(date1-date2)
可以工作,但我不知道它返回的是什么数据。
发布于 2009-06-20 08:28:58
这看起来有点老套,但适用于1970年到2030年之间的日期(在32位arch上)。您实际上是将日期时间值转换为整数,对它们求平均值,然后将平均值转换回日期时间值。
SELECT
from_unixtime(
avg(
unix_timestamp(date_one)-unix_timestamp(date_two)
)
)
FROM
some_table
WHERE
some-restriction-applies
有可能有一个更好的解决方案,但这将使您在紧要关头。
发布于 2010-09-28 21:25:17
select avg(datediff(date1,date2))
select avg(timediff(datetime,datetime))
发布于 2009-06-20 09:06:26
SELECT date_one + (date_two - date_one) / 2 AS average_date
FROM thetable
WHERE whatever
你不能把日期相加,但你可以减去它们,得到一个时间间隔,你可以减半,然后加回第一个日期。
https://stackoverflow.com/questions/1021947
复制相似问题