如何在“选择”SQL查询中将时间范围拆分为间隔

时间:2018-01-23 16:53:43

标签: mysql sql mysql-workbench

我是SQL的新手,我正在编写一些SQL查询。 我遇到了一个阻碍者,你们可以帮我解决一个问题吗?

这是我使用的查询(仅使用1行作为参考):

Select 
USER_NAME, 
TIME(CONVERT_TZ(START_TIME, '+00:00','America/Los_Angeles')) as 'PST Start',
TIME(CONVERT_TZ(END_TIME, '+00:00','America/Los_Angeles')) as 'PST End',
name as 'Type',
date(start_time) as 'Date',
WORKGROUP_NAME
from USER_SCHEDULE_INSTANCES 
where user_name = 'prateeth' 
and date(START_TIME) = '2018-01-01'
limit 1

这是输出

USER_NAME   PST Start   PST End     Date        Type    WORKGROUP_NAME
prateeth    06:00:00    09:00:00    2018-01-01  Work    NACS Command Center

如何在不使用宏的情况下将其分成半小时间隔并接收如下输出:

USER_NAME   PST Start   PST End     Date        Type    WORKGROUP_NAME
prateeth    06:00:00    06:30:00    2018-01-01  Work    NACS Command Center
prateeth    06:30:00    07:00:00    2018-01-01  Work    NACS Command Center
prateeth    07:00:00    07:30:00    2018-01-01  Work    NACS Command Center
prateeth    07:30:00    08:00:00    2018-01-01  Work    NACS Command Center
prateeth    08:00:00    08:30:00    2018-01-01  Work    NACS Command Center
prateeth    08:30:00    09:00:00    2018-01-01  Work    NACS Command Center

1 个答案:

答案 0 :(得分:1)

评论回答。创建一个时间表并填充您要查找的时间范围。这些方面的东西:

Table Name: Dim_Time 
example data:

ID    starttime   endtime
1     06:00       06:30
2     06:30       07:00
etc

当您需要拆分为时间范围时,在您的from语句中交叉连接到此表。

From  USER_SCHEDULE_INSTANCES 
join dim_time on 1=1

您可以在此时间表中添加第二个ID列,以便您可以在此时间点中分解多个“版​​本”。

希望很清楚,如果您需要更多,请发表评论。