繁体   English   中英

mysql如何检查数据时间是否存在?

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM