MySQL 时间平均值(以毫秒为单位)

标签 mysql time average

创建和插入数据是

CREATE TABLE IF NOT EXISTS `testTime` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `startTime` time(3) DEFAULT NULL,
  `endTime` time(3) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=40910 DEFAULT CHARSET=utf8;

INSERT INTO `testTime` (`startTime`, `endTime`) VALUES
('00:00:37.185', '00:00:32.141'),
('00:00:41.229', '00:00:32.255'),
('00:00:37.278', '00:00:23.548'),
('00:00:37.205', '00:00:28.479'),
('00:00:41.343', '00:00:25.354'),
('00:00:38.703', '00:00:38.645'),
('00:00:37.990', '00:00:32.182'),
('00:00:37.858', '00:00:36.589');

我可以求和、比较,但求平均值时遇到问题。我会使用 AVG 函数,因为有时我会使用多个时间列进行计算。我尝试:

SELECT
id,
SEC_TO_TIME(startTime+endTime) TotalSum,
SEC_TO_TIME(startTime - endTime) Diff,
TIME_TO_SEC(AVG(SEC_TO_TIME(startTime + endTime))) AverageT            
FROM testTime
Group by id;

我需要“00:01:09.326”格式的返回值。使用 Sum,diff 工作得很好,但不知道如何使用 avg 来做到这一点。

平均结果应该是:

00:00:34.663
00:00:36.742
00:00:30.413
00:00:32.842
00:00:33.348
00:00:38.674
00:00:35.086
00:00:37.223

谢谢

最佳答案

如果您想要列值的平均值,则应该使用 AVG(),但从您的预期结果来看,我发现您想要的是 startTime 的平均值> 和每行的 endTime
因此,添加 startTimeendTime 并除以 2:

SELECT
  id,
  SEC_TO_TIME(startTime + endTime) TotalSum,
  SEC_TO_TIME(startTime - endTime) Diff,
  SEC_TO_TIME((startTime + endTime) / 2) AverageT            
FROM testTime

由于 Id 是唯一的,我认为不需要 GROUP BY id
请参阅demo .
结果:

| id  | TotalSum     | Diff         | AverageT        |
| --- | ------------ | ------------ | --------------- |
| 1   | 00:01:09.326 | 00:00:05.044 | 00:00:34.663000 |
| 2   | 00:01:13.484 | 00:00:08.974 | 00:00:36.742000 |
| 3   | 00:01:00.826 | 00:00:13.730 | 00:00:30.413000 |
| 4   | 00:01:05.684 | 00:00:08.726 | 00:00:32.842000 |
| 5   | 00:01:06.697 | 00:00:15.989 | 00:00:33.348500 |
| 6   | 00:01:17.348 | 00:00:00.058 | 00:00:38.674000 |
| 7   | 00:01:10.172 | 00:00:05.808 | 00:00:35.086000 |
| 8   | 00:01:14.447 | 00:00:01.269 | 00:00:37.223500 |

结果:

关于MySQL 时间平均值(以毫秒为单位),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58216096/

相关文章:

mysql - 将 Mysql CASE select 语句结果存储在一个变量中

mysql - 如何在 SQL 中水平打印表格?

带有全文索引搜索的 mySQL 查询,如果它们在另一个表中有数据,则返回 X 个结果

mysql - SQL查询 "like"运算符错误,当字段为空时

r - R中的日期时间转换

java - Android 与 Timepicker 比较字符串

bash - 如何解决 bash grep 错误以获得行的平均值

c - 从C中的链表中删除一些元素

c++ - 系统时间、本地时间、文件时间和正常时间

postgresql - 需要明智地选择员工部门的平均年龄