Как правильно обобщить как «Время заказа» + «Время выхода» - mysql (добавьте часы, а не секунды)

0

В базе данных MySQL я создал покинуть таблицу:

+--------+---------+---------+-------------+---------+--------------------------
|ID_LEAVE|ID_WORKER| FNAME | LNAME | BEGIN_DATE         | END_DATE             | 
+--------+---------+---------+---------+------------+--------------------+------
| 1      |   1     | ALAN  | MAX   |2019-03-19 07:00:00 |2019-03-20 15:00:00   | 
| 2      |   1     | ALAN  | MAX   |2019-03-21 07:00:00 |2019-03-21 15:00:00   |
+--------+---------+---------+----------------------+---------------------------

"Рабочий стол"

+----------+---------+---------+
|ID_WORKER |  FNAME  | LNAME   |
+----------+---------+----------
| 1        |  ALAN   |  MAX    |
| 2        |  MARK   |  DARK   |
+----------+---------+---------+

Таблица "Заказы":

+----------+--------------+---------------+
|ID_ORDER  |  DESC_ORDER  | NUMBER_ORDER  |
+----------+--------------+---------------+
| 20       |  TEST        |  TEST         |
+----------+--------------+---------------+

Таблица "Order_status":

+----------+---------+---------+---------------------+-------------------+------------+
| Id_status|ID_WORKER| ID_ORDER| BEGIN_DATE          | END_DATE          | ORDER_DONE |
+----------+---------+---------+----------+------------+---------+--------------------+
| 30       |   1     |    20   |2019-03-18 06:50:35  |2019-03-18 15:21:32|  NO        |
| 31       |   1     |    20   |2019-03-20 06:44:12  |2019-03-20 15:11:23|  NO        |
| 32       |   1     |    20   |2019-03-22 06:50:20  |2019-03-22 12:22:33|  YES       |
| 33       |   2     |    20   |2019-03-18 06:45:11  |2019-03-18 15:14:45|  NO        |
| 34       |   2     |    20   |2019-03-20 06:50:22  |2019-03-20 15:10:32|  NO        |
| 35       |   2     |    20   |2019-03-22 06:54:11  |2019-03-22 11:23:45|  YES       |
+----------+---------+---------+------------+---------+-------------------+-----------+ 

Что я сделал:

Я могу суммировать "общее время" рабочих друг друга (в таблице order_status) по заказу, включая суммирующее "время выхода" из таблицы Leave и суммирующее "время заказа" + "время отпуска" (частично). Я правильно выбрал рабочие заказы (LNAME, FNAME) (DESC_ORDER и NUMBER_ORDER) и "ВСЕГО ВРЕМЕНИ" для заказов друг друга. Я написал команду mysql ниже:

SELECT workers.fname, 
       workers.lname, 
       order_statusAgg.number_order,
       workers.id_worker,
       order_statusAgg.desc_order, 
       SEC_TO_TIME(SUM(order_statusAgg.stime)) AS 'ORDER TIME', 
       IFNULL(SEC_TO_TIME(SUM(leaveAgg.vtime)),'00:00:00') AS 'LEAVE TIME'
       time_format(SEC_TO_TIME(SUM(order_statusAgg.stime)) +  IFNULL(SEC_TO_TIME(SUM(leaveAgg.vtime)),'00:00:00'), '%H:%i:%s') AS 'TOTAL TIME'
FROM   workers 
LEFT JOIN (
SELECT leave.id_worker, time_format(SUM((datediff(leave.end_date, leave.begin_date) + 1) * (time(leave.end_date) - time(leave.begin_date))), '%H:%i:%s') AS vtime 
FROM leave
GROUP BY leave.id_worker 
) leaveAgg
               ON leaveAgg.id_worker = workers.id_worker
       LEFT JOIN (
SELECT order_status.id_worker, orders.number_order, orders.desc_order, SUM((Time_to_sec(order_status.end_date) - 
                       Time_to_sec(order_status.begin_date))) AS stime
FROM order_status
           INNER JOIN orders 
               ON orders.id_order = order_status.id_order
GROUP BY order_status.id_worker
) order_statusAgg
               ON workers.id_worker = order_statusAgg.id_worker 

WHERE  order_statusAgg.number_order LIKE 'TEST'
GROUP BY workers.id_worker

Тогда я получаю результат:

+---------+---------+---------------+------------+------------+--------------+-----------+
|  FNAME  | LNAME   |  NUMBER_ORDER | DESC_ORDER | ORDER TIME | LEAVE_TIME   | TOTAL TIME|
+---------+---------+---------------+------------+------------+--------------+-----------+
|  ALAN   |  MARK   | TEST          | TEST       | 22:30:21   |   24:00:00   |  22:30:45 |
+---------+---------+---------------+------------+------------+--------------+-----------+
|  MARK   |  GREEN  | TEST          | TEST       | 21:19:18   |   00:00:00   |  21:19:18 |
+---------+---------+---------------+------------+------------+--------------+-----------+

Но, с другой стороны, этот запрос добавил только 24 секунды, а не 24 часа. Возможно, из-за этой строки запроса:

time_format(SEC_TO_TIME(SUM(order_statusAgg.stime)) +  IFNULL(SEC_TO_TIME(SUM(leaveAgg.vtime)),'00:00:00'), '%H:%i:%s') AS 'TOTAL TIME'

которые должны быть:

+---------+---------+---------------+------------+------------+--------------+-----------+
|  FNAME  | LNAME   |  NUMBER_ORDER | DESC_ORDER | ORDER TIME | LEAVE_TIME   | TOTAL TIME|
+---------+---------+---------------+------------+------------+--------------+-----------+
|  ALAN   |  MARK   | TEST          | TEST       | 22:30:21   |   24:00:00   |  46:30:21 |
+---------+---------+---------------+------------+------------+--------------+-----------+
|  MARK   |  GREEN  | TEST          | TEST       | 21:19:18   |   00:00:00   |  21:19:18 |
+---------+---------+---------------+------------+------------+--------------+-----------+

Например: ALAN MARK для ТЕСТА заказа: Общее время = Время заказа + время выхода Общее время = 22:30:21 + 24:00:00 = 46:30:21

Может кто-нибудь показать, какой запрос мне написать? Есть идеи? Спасибо за любую помощь или совет!

Теги:
datetime
sum
time-format

1 ответ

1
Лучший ответ

Как вы сказали Общее время = Время заказа + время выхода Общее время = 22:30:21 + 24:00:00 = 46:30:21

так что один из способов решить эту проблему - использовать функцию addtime

ADDTIME('22:30:21',IFNULL('24:00:00','00:00:00')) as 'TOTAL TIME'
  • 1
    О боже, почему я не попробовал это раньше ... Я только изменил ваш ответ, и он работает. Большое спасибо за совет.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню