gpt4 book ai didi

mysql - 如何正确总结为 “Order Time” + “leave Time” - mysql (添加小时而不是秒)

转载 作者:行者123 更新时间:2023-11-29 09:47:50 24 4
gpt4 key购买 nike

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

“ worker 表”

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

“订单”表:

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

“订单状态”表:

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

我做了什么:

我可以总结订单上每个其他 worker 的“总时间”(在 order_status 表中),包括总结休假表中的“休假时间”以及总结“订单时间”+“休假时间”(部分)。我也正确地从其他 worker 那里选择了 worker (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

有人可以告诉我应该写什么样的查询吗?有任何想法吗?感谢您的帮助或建议!

最佳答案

如您所说,总时间 = 下单时间 + 离开时间 总时间 = 22:30:21 + 24:00:00 = 46:30:21

解决这个问题的一种方法是使用 addtime功能

ADDTIME('22:30:21',IFNULL('24:00:00','00:00:00')) as `TOTAL TIME`

关于mysql - 如何正确总结为 “Order Time” + “leave Time” - mysql (添加小时而不是秒),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55352125/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com