MySQL如何统计时间差的平均值

MySQL如何统计时间差的平均值

说到时间差和平均值,那自然离不开两个函数:
1、TIMEDIFF(endTime,startTime) : 计算两个日期的时间差
2、AVG():返回表达式的平均值
举个🌰:
在这里插入图片描述
假设你根据项目中的需求检索出了两个日期,现在需要计算两个日期的时间差

SELECT
	ProcessDate,
	CreateTime,
	TIMEDIFF( ProcessDate, CreateTime ) AS diffTime 
FROM
	WF_Task 
WHERE
	InstanceID = '7c4b7506-db10-9194-3aa2-1a7fa5671fa3'

在这里插入图片描述

第三列计算出了两个日期的差值
第一列:56s
第二列:21s
第三列:0s
第四列:80s
第五列:56s
所以平均数应该是:42.6s

SQL:
先使用TIME_TO_SEC(time): 将日期格式转换为秒,然后使用AVG()对该列求平均值

SELECT
	AVG(
		TIME_TO_SEC(
		TIMEDIFF( ProcessDate, CreateTime ))) AS timeDiff 
FROM
	WF_Task 
WHERE
	InstanceID = '7c4b7506-db10-9194-3aa2-1a7fa5671fa3'

在这里插入图片描述
得出结果。
接下来可以使用ROUND(a,b)函数保留一位小数或者取整(四舍五入)

SELECT
	ROUND( AVG( TIME_TO_SEC( TIMEDIFF( ProcessDate, CreateTime ))), 0 ) AS timeDiff 
FROM
	WF_Task 
WHERE
	InstanceID = '7c4b7506-db10-9194-3aa2-1a7fa5671fa3'

在这里插入图片描述
你还可以使用SEC_TO_TIME(seconds)函数将秒变成时间格式

SELECT
	SEC_TO_TIME(
	ROUND( AVG( TIME_TO_SEC( TIMEDIFF( ProcessDate, CreateTime ))), 0 )) AS timeDiff 
FROM
	WF_Task 
WHERE
	InstanceID = '7c4b7506-db10-9194-3aa2-1a7fa5671fa3'

在这里插入图片描述
得出平均数为43s

本文只谈用法,没有考虑效率问题,望见谅

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

暮春二十四

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值