我有一个表预订,其中有两列 job_time_beg 和 job_time_end,工作从 8:00 开始一直持续到 16:00 现在我需要确定可用时间是否与给定时间重叠,以便我知道我不想在给定时间内预订时间。
我在用
select count(*)as cnt from orders
where job_date = '2021-02-04'
and job_truck = '24'
and ((job_time_beg >= '10:00' and job_time_beg < '12:00')
or (job_time_end > '(11):00' and job_time_end <= '12:00'))
AND order_status_id in (1,5)
这在大多数情况下工作正常,但如果在 8:00 和 11:00 之间有预订,则此查询不起作用,并显示 10:00 到 12:00 的时间可用,该时间在 8:00 和 11:00 之间重叠
我也尝试过
SELECT count(*) as cnt
FROM orders
WHERE
job_date = '$data'
and job_truck = '$truck' and
(
'$start' BETWEEN job_time_beg and job_time_end
OR
'$end' BETWEEN job_time_beg and job_time_end
)
AND order_status_id in (1,5)
它适用于 8:00 和 11:00 重叠,但在预订可用时不起作用,如果我们预订 8:00 至 10:00 并且我们有时间,则前开始时间可以等于下一次预订的结束时间10:00 至 12:00 这不会重叠,因为我们可以从 10:00 开始安排下一次预订。
请看一下sql fiddlesqlfiddle http://sqlfiddle.com/#!9/a0b380/1
两个时间段重叠的逻辑是:
- 第一个在第二个结束之前开始。
- 第一个结束后第二个开始。
在您的查询中,逻辑将是:
SELECT count(*) as cnt
FROM orders
WHERE job_date = @job_date AND
job_truck = @truck AND
@start < job_time_end AND
@end > job_time_begin AND
order_status_id IN (1, 5);
请注意命名参数的使用。不要将查询字符串与参数值混在一起!。参数可以防止意外且难以调试的语法错误。它们还保护代码免受 SQL 注入攻击。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)