Расчет времени с MySQL TIMEDIFF - PullRequest
       18

Расчет времени с MySQL TIMEDIFF

1 голос
/ 29 апреля 2010

У меня есть следующая таблица:

mysql> SELECT id,start1,stop1,start2,stop2 FROM times;
+----+---------------------+---------------------+---------------------+---------------------+
| id | start1              | stop1               | start2              | stop2               |
+----+---------------------+---------------------+---------------------+---------------------+
|  4 | 2010-04-23 08:05:00 | 2010-04-23 12:15:00 | 2010-04-23 12:45:00 | 2010-04-23 16:50:00 | 
|  2 | 2010-04-26 09:30:00 | 2010-04-26 12:10:00 | 2010-04-26 12:50:00 | 2010-04-26 16:50:00 | 
|  7 | 2010-04-28 08:45:00 | 2010-04-28 11:45:00 | 2010-04-28 13:10:00 | 2010-04-28 17:29:00 | 
|  6 | 2010-04-27 09:30:00 | 2010-04-27 12:15:00 | 2010-04-27 12:55:00 | 2010-04-27 18:44:00 | 
+----+---------------------+---------------------+---------------------+---------------------+

Я хочу суммировать общее рабочее время и разницу с «необходимыми рабочими часами».Он хорошо работает с приведенным ниже утверждением, но по неизвестным причинам не работает для id 6. Поля start * / stop * имеют формат datetime.

SELECT *, TIME_FORMAT(TIMEDIFF(totaltime,'08:24'),'%H:%i') AS diff,
totaltime > '08:24' AS redorgreen FROM
(
SELECT 
    DATE_FORMAT(start1,'%a %e. %M %Y') AS date,
    TIME_FORMAT(SUM(TIMEDIFF(stop1,start1) + TIMEDIFF(stop2,start2)),'%H:%i') AS totaltime,
    TIME_FORMAT(start1,'%H:%i') AS start1,
    TIME_FORMAT(stop1,'%H:%i') AS stop1,
    TIME_FORMAT(start2,'%H:%i') AS start2,
    TIME_FORMAT(stop2,'%H:%i') AS stop2,
    id as id
FROM times GROUP BY id ASC
) AS somethingwedontneed;

Это результат:

select id,
       TIME_FORMAT(SUM(TIMEDIFF(stop1,start1) + TIMEDIFF(stop2,start2)),'%H:%i') 
       AS totaltime from times group by id;
+----+-----------+
| id | totaltime |
+----+-----------+
|  2 | 06:40     | 
|  4 | 08:15     | 
|  6 | NULL      | 
|  7 | 07:19     | 
+----+-----------+

Заранее благодарим за каждый намек.

Ответы [ 2 ]

3 голосов
/ 29 апреля 2010

SELECT id, TIMEDIFF (остановка1, запуск1), TIMEDIFF (остановка2, запуск2), ДОБАВЛЕНИЕ (TIMEDIFF (остановка1, старт1), TIMEDIFF (остановка2, старт2)), TIME_FORMAT (ДОБАВЛЕНИЕ (TIMEDIFF (остановка 1, запуск1)), TIMEDIFF ( stop2, start2)), '% H:% i') AS totaltime С времен GROUP BY id

0 голосов
/ 13 июня 2012

Попробуйте обернуть '08:24' в TIME(), то есть TIME('08:24').

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...