MySQL AVG времени с миллисекундами - PullRequest
0 голосов
/ 03 октября 2019

Данные для создания и вставки

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

Спасибо

1 Ответ

0 голосов
/ 05 октября 2019

Вам следует использовать AVG(), если вы хотите получить среднее значение для столбца, но из ваших ожидаемых результатов я вижу, что вы хотите получить среднее значение startTime и endTime для каждой строки. Поэтому добавьте startTime и endTime и разделите на 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. Смотрите демо . Результаты:

| 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 |

Результаты:

...