首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在MySQL中计算日期的平均值?

如何在MySQL中计算日期的平均值?
EN

Stack Overflow用户
提问于 2009-06-20 16:22:06
回答 6查看 26.4K关注 0票数 21

如何在MySQL中计算两个日期之间的平均值?我对时间值、小时和分钟更感兴趣。

在一张桌子上:

代码语言:javascript
运行
复制
| date_one   | datetime |
| date_two   | datetime |

执行如下查询:

代码语言:javascript
运行
复制
 SELECT AVG(date_one-date_two) FROM some_table WHERE some-restriction-applies;

编辑:

AVG(date1-date2)可以工作,但我不知道它返回的是什么数据。

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2009-06-20 16:28:58

这看起来有点老套,但适用于1970年到2030年之间的日期(在32位arch上)。您实际上是将日期时间值转换为整数,对它们求平均值,然后将平均值转换回日期时间值。

代码语言:javascript
运行
复制
SELECT
    from_unixtime(
        avg(
            unix_timestamp(date_one)-unix_timestamp(date_two)
        )
    )
FROM
    some_table
WHERE
    some-restriction-applies

有可能有一个更好的解决方案,但这将使您在紧要关头。

票数 26
EN

Stack Overflow用户

发布于 2010-09-29 05:25:17

代码语言:javascript
运行
复制
select avg(datediff(date1,date2))
select avg(timediff(datetime,datetime))
票数 9
EN

Stack Overflow用户

发布于 2009-06-20 17:06:26

代码语言:javascript
运行
复制
SELECT date_one + (date_two - date_one) / 2 AS average_date
FROM thetable
WHERE whatever

你不能把日期相加,但你可以减去它们,得到一个时间间隔,你可以减半,然后加回第一个日期。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1021947

复制
相关文章

相似问题

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