- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个查询,该查询会得出给定时间段/天数内资源的总预订时间。我想将预订的总金额拆分为按小时分组。
SELECT
resourceID,
SEC_TO_TIME(
SUM(
CASE WHEN DATEDIFF(DATE(endDatetime), DATE(startDatetime)) = 0 THEN
GREATEST(TIME_TO_SEC(TIMEDIFF(LEAST('16:00:00', TIME(endDatetime)), LEAST(GREATEST('08:00:00', TIME(startDatetime)), '16:00:00'))), 0)
ELSE
TIME_TO_SEC(TIMEDIFF('16:00:00', LEAST(GREATEST('08:00:00', TIME(startDatetime)), '16:00:00')))
+ TIME_TO_SEC(TIMEDIFF(GREATEST('08:00:00', LEAST('16:00:00', TIME(endDatetime))), '08:00:00'))
+ ((DATEDIFF(DATE(endDatetime), DATE(startDatetime)) - 1) * TIME_TO_SEC(TIMEDIFF('16:00:00', '08:00:00')))
END
)
) AS booked_time
FROM table_name
WHERE resourceID = 1
AND startDatetime BETWEEN '2019-01-01 00:00:00' AND '2019-01-05 23:59:59'
GROUP BY resourceID
https://dbfiddle.uk/?rdbms=mysql_8.0&fiddle=dbacebf2b5aa3ca8233bab7273f1363c
这将返回总预订时间。我希望结果每小时分组:外汇。
2019-01-01 08:00-09:00, BookedTime 0:30
2019-01-01 09:00-10:00, BookedTime 1:00
2019-01-01 10:00-11:00, BookedTime 0:30
2019-01-02 08:00-09:00, BookedTime 0:30
2019-01-02 09:00-10:00, BookedTime 1:00
2019-01-02 10:00-11:00, BookedTime 0:30
等等。
编辑:
我也希望得到以下结果的解决方案:
08:00-09:00, BookedTime 6:30
09:00-10:00, BookedTime 10:00
10:00-11:00, BookedTime 3:30
不同之处在于您将多个日期的每小时之间的总预订时间相加。
最佳答案
<强> SQL DEMO
首先,您需要为所有日期和时间创建一个表格。
注意100年的数据只需要100 * 365 * 24 = 876000行
您可以选择在WHERE
条件上创建的日期范围
CREATE TABLE allDays as
select DATE_ADD(selected_date, INTERVAL start_time HOUR) as start_time
, DATE_ADD(selected_date, INTERVAL end_time HOUR) as end_time
from
(select adddate('1970-01-01',t4.i*10000 + t3.i*1000 + t2.i*100 + t1.i*10 + t0.i) selected_date
from
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t0,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t1,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t2,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t3,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t4
) v
CROSS JOIN (
SELECT 00 as start_time, 01 as end_time UNION
SELECT 01 as start_time, 02 as end_time UNION
SELECT 02 as start_time, 03 as end_time UNION
SELECT 03 as start_time, 04 as end_time UNION
SELECT 04 as start_time, 05 as end_time UNION
SELECT 05 as start_time, 06 as end_time UNION
SELECT 06 as start_time, 07 as end_time UNION
SELECT 07 as start_time, 08 as end_time UNION
SELECT 08 as start_time, 09 as end_time UNION
SELECT 09 as start_time, 10 as end_time UNION
SELECT 10 as start_time, 11 as end_time UNION
SELECT 11 as start_time, 12 as end_time UNION
SELECT 12 as start_time, 13 as end_time UNION
SELECT 13 as start_time, 14 as end_time UNION
SELECT 14 as start_time, 15 as end_time UNION
SELECT 15 as start_time, 16 as end_time UNION
SELECT 16 as start_time, 17 as end_time UNION
SELECT 17 as start_time, 18 as end_time UNION
SELECT 18 as start_time, 19 as end_time UNION
SELECT 19 as start_time, 20 as end_time UNION
SELECT 20 as start_time, 21 as end_time UNION
SELECT 21 as start_time, 22 as end_time UNION
SELECT 22 as start_time, 23 as end_time UNION
SELECT 23 as start_time, 24 as end_time
) t
where selected_date between '2018-12-31' and '2019-01-10'
;
现在您可以在这些时段之间分配所有预订
SELECT *
, GREATEST( a.start_time , t.startDatetime ) as book_start
, LEAST( a.end_time , t.endDatetime ) as book_end
, TIMEDIFF( LEAST( a.end_time , t.endDatetime )
, GREATEST( a.start_time , t.startDatetime ) ) as time_diff
FROM allDays a
LEFT JOIN table_name t
ON a.start_time <= t.endDatetime
AND a.end_time >= t.startDatetime
WHERE start_time < '2019-01-05 23:59:59'
AND end_time > '2019-01-01 00:00:00'
ORDER BY 1
;
现在您可以对每个时段进行分组并添加预订时间
With time_slots as (
SELECT *
, GREATEST( a.start_time , t.startDatetime ) as book_start
, LEAST( a.end_time , t.endDatetime ) as book_end
, TIMEDIFF( LEAST( a.end_time , t.endDatetime )
, GREATEST( a.start_time , t.startDatetime ) ) as time_diff
FROM allDays a
LEFT JOIN table_name t
ON a.start_time <= t.endDatetime
AND a.end_time >= t.startDatetime
WHERE start_time < '2019-01-05 23:59:59'
AND end_time > '2019-01-01 00:00:00'
ORDER BY 1
)
SELECT start_time
, end_time
, SEC_TO_TIME( SUM( TIME_TO_SEC( `time_diff` ) ) ) AS timeSum
FROM time_slots
GROUP BY start_time, end_time
ORDER BY 1
;
关于mysql - 将结果分组为每小时的子组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58434492/
我有 0 小时、3 小时、12 小时、24 小时、48 小时的数据组……我想绘制这些数据的图表,以便保留时间的比例。 runs <- c(1:25) hours <- as.factor(c(0, 3
例如,如果我选择了时间:下午 3 点和小时数:5 小时,则得到 (8pm) 作为答案“ 最佳答案 let calendar = Calendar.current let date = calendar
我有一个包含两个日期时间字段的表单。用户输入日期 (yyyy-mm-dd) 和时间(3 个框;小时、分钟、上午/下午)。 出于某种原因,第一个没有保存为 24 小时制。 以下数据为输入结果: 2011
我一直在尝试使用导出单位进行计算,但到目前为止我还没有取得任何成果。 我已经尝试过mathjs ,但如果我输入 1 小时 * 1 英里/小时,我会得到 UnsupportedTypeError: Fu
我有两组要运行的 cronjob。第一个应该每 3 小时运行一次,第二个也应该每 3 小时运行一次,但比第一组晚一个小时。什么是正确的语法? // every 3 hours 17 */3 * *
我知道 AWS 中的预留实例更多的是计费而不是实际实例——它们没有附加到实际实例——我想知道: 如果我在特定区域和可用区中购买特定时间的预留实例 - 如果我每天 24 小时使用单个实例与运行 24 个
我试过: seq( from=as.POSIXct("2012-1-1 0", tz="UTC"), to=as.POSIXct("2012-1-3 23", tz="UTC"),
我有一个带有“日期”列的表。我想按小时分组指定日期。 最佳答案 Select TO_CHAR(date,'HH24') from table where date = TO_DATE('2011022
我知道如何在 SQL (SQL Server) 中获取当前日期,但要获取当天的开始时间: select dateadd(DAY, datediff(day, 0, getdate()),0) (res
我正在尝试在游戏之间创建一个计时器,以便用户在失去生命后必须等待 5 分钟才能再次玩游戏。但是我不确定最好的方法是什么。 我还需要它来防止用户在“设置”中编辑他们的时间。 实现这一目标的最佳方法是什么
我的查询有误。该错误显示预期的已知函数,得到“HOUR”。如果我删除这部分,查询将正常工作 (AND HOUR({$nowDate}) = 11) SELECT c FROM ProConvocati
var d1 = new Date(); var d2 = new Date(); d2.setHours(d1.getHours() +01); alert(d2); 这部分没问题。现在我试图在 (
我正在构建一个用于练习的基本时钟应用程序,但出于某种原因,时间不会自动更改为最新的分钟或小时。例如,当前时间是 17:56,但它显示的是 17:54,这是我打开应用程序的最后时间。 NSDate *n
我创建了一张图片,我想将其用作页面的 hr。当它被上传时,它一直向左对齐。我希望它居中,在标题下。这是我的 CSS 代码: .section-underline { height: 35px
这个问题已经有答案了: Getting difference in seconds from two dates in JavaScript (2 个回答) 已关闭 4 年前。 我想计算两个具有不同格
我需要计算到某个日期/时间的剩余时间(天/小时)。 但是,我没有使用静态日期。 假设我在 每个星期日 的 17:00 有一个事件。我需要显示到下一个事件的剩余时间,即即将到来的星期日 17:00。 我
我正在执行这个脚本: SELECT EXTRACT(HOUR FROM TIMEDIFF('2009-12-12 13:13:13', NOW())); 我得到:-838。这是提取时 MySQL 可以
复制代码 代码如下: /** * 小时:分钟的正则表达式检查<br> * <br> * @param pInput 要检查的字符串 * @return boolean 返
连wifi5元/小时 独领风骚 朕好帅 今晚你是我的人 十里桃花 高端定制厕所VP专用 一只老母猪 在家好无聊 你爹的wifi 密码是叫爸爸全拼 关晓彤和鹿晗分手了吗 蹭了我的
我有以下数据框列: 我需要将 csv 列中的对象字符串数据转换为总秒数。 示例:10m -> 600s 我试过这段代码: df.duration = str(datetime.timedelta(df
我是一名优秀的程序员,十分优秀!