[英]How to check the data time is exist in mysql?
有一个时间表系统,
每个时隙只有一个预订,
我这样保存数据:
start_time datetime
duration int
这意味着,如果从2015-12-20 21:00:00 to 2015-12-20 23:00:00
进行预订
start_time 2015-12-20 21:00:00
duration 3
现在,我想检查插入数据是否为:
1)时间范围是否与存在记录重叠?
2)超过24小时? 例如。 预订从22:00开始,持续时间为5小时
我尝试类似的情况,但24小时无法检查
$start_time = new DateTime($_POST['start_time']);
$end_time = new DateTime($booking_time);
$end_time = $end_time->add(new DateInterval('PT' . $_POST['duration']. 'H'));
$_POST['start_time'] >= start_time AND end_time <= start_time
如何解决?
感谢您的帮助
对于第二个条件,您是否要检查预订是否在开始的同一天结束?
在这种情况下,以下选择将返回与此条件匹配的预订:
SELECT start_time, duration FROM bookings WHERE DATE(start_time) <> DATE(TIMESTAMPADD(HOUR, duration, start_time));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.