用于检查房间的mysql是否存在具有持续时间的特定日期

时间:2016-01-11 09:09:51

标签: mysql sql mysqli

我有特定日期的两次检查室。

MY TABLE LIKE THIS

我尝试跟随两个查询运行一些时间权限但是,当我选择上午10:00到下午12:00时错误的结果意味着不返回任何记录。

QUERY-1

SELECT 1 FROM `timetable_details` WHERE (
        ((`td_from` <= '10:00:00') AND (`td_to` > '10:00:00')) 
        OR 
        ((`td_from` < '12:20:00') AND (`td_to` >= '12:20:00'))

    ) AND ((`td_room`='1') AND (`td_date`='2016-01-25'))

QUERY-2

SELECT 1 FROM `timetable_details` WHERE (
            (`td_from` > '07:00:00') AND (`td_to` < '08:00:00')
      ) AND ((`td_room`='1') AND (`td_date`='2016-01-25'))

我有td_id = 4号码行,但不是返回。

提前致谢。

1 个答案:

答案 0 :(得分:3)

您可以对between OR condition使用SELECT 1 FROM `timetable_details` WHERE (((((`td_from` BETWEEN '10:00:00' AND '12:30:00') OR (`td_to` BETWEEN '10:00:00' AND '12:30:00')) AND ((`td_room`='1') AND (`td_date`='2016-01-25') AND (`td_status` IS NULL))) AND (`td_from` <> '12:30:00')) AND (`td_to` <> '10:00:00')) ,如下所示:

{{1}}

希望你能得到正确的结果。