Как правильно подвести итог как «Leave Time» + «Total Time» - mysql - PullRequest
0 голосов
/ 21 марта 2019

ОК - я изменил эту концепцию.В базе данных mysql я создал таблицу «exit»:

+--------+---------+---------+-------------+---------+-------------------------------+
|ID_LEAVE|ID_WORKER| FNAME   | LNAME   | BEGIN_DATE          | END_DATE              | 
+--------+---------+---------+---------+------------+--------------------+-----------
| 1      |   1     | DAVID   | BUCS    |2019-03-19 07:00:00  |2019-03-19 15:00:00    | 
+--------+---------+---------+----------------------+--------------------+----------- 
| 2      |   2     | MARK    | GREEN   |2019-03-21 07:00:00  |2019-03-21 15:00:00    |
+--------+---------+---------+----------------------+--------------------------------+

Таблица «Workers»:

+----------+---------+---------+
|ID_WORKER |  FNAME  | LNAME   |
+----------+---------+----------
| 1        |  DAVID  |  BUCS   |
+----------+---------+----------
| 2        |  MARK   |  GREEN  |
+----------+---------+---------+

Таблица «Orders»:

+----------+--------------+---------------+
|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) в заказе, в том числе с помощью "отпускать sumarizing"Время »из таблицы.Я правильно выбрал рабочие заказы (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 'TOTAL TIME', 
       SEC_TO_TIME(SUM(leaveAgg.ltime)) AS 'LEAVE TIME' 
FROM   workers 
INNER JOIN (
SELECT leave.id_worker, SUM((Time_to_sec(leave.end_date) - 
                       Time_to_sec(leave.begin_date))) AS ltime
FROM leave
GROUP BY leave.id_worker
) leaveAgg
               ON leaveAgg.id_worker = workers.id_worker
       INNER 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 | TOTAL TIME | LEAVE_TIME   | 
    +---------+---------+---------------+------------+------------+--------------+
    |  DAVID  |  BUCS   | TEST          | TEST       | 22:30:21   |   8:00:00    |   
    +---------+---------+---------------+------------+------------+--------------+
    |  MARK   |  GREEN  | TEST          | TEST       | 21:19:18   |   8:00:00    |   
    +---------+---------+---------------+------------+------------+--------------+

что я хотел бы сделать дальше:

Что яЯ хотел бы сделать следующее: я пытаюсь обобщить все из них, я имею в виду: ОБЩЕЕ ВРЕМЯ + LEAVE_TIME для каждого работника.Например:

 +---------+---------+---------------+------------+------------+-------------+----------+
|  FNAME  | LNAME   |  NUMBER_ORDER | DESC_ORDER | TOTAL TIME | LEAVE_TIME   | SUM_TIME |
+---------+---------+---------------+------------+------------+--------------+----------+
|  DAVID  |  BUCS   | TEST          | TEST       | 22:30:21   |   8:00:00    | 30:30:21 |
+---------+---------+---------------+------------+------------+--------------+----------+
|  MARK   |  GREEN  | TEST          | TEST       | 21:19:18   |   8:00:00    | 29:19:18 | 
+---------+---------+---------------+------------+------------+--------------+----------+

Я пытался добавить в верхний запрос:

SEC_TO_TIME(SUM(SEC_TO_TIME(SUM(order_statusAgg.ttime) + SUM(leaveAgg.stime)) AS 'SUM_TIME';

Но я знаю, что это плохая идея.Так что я понятия не имею, как это решить.У кого-нибудь есть идеи, как это решить?Есть идеи.Большое спасибо за любую помощь!

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