MySQL选择时间戳不重叠的地方

标签 mysql

每个用户在表中都有多个预订,我需要获取用户详细信息和预订详细信息,其中预订开始和结束日期与用户通过的日期不重叠。

用户

id | name
---------
1  | Ryan
2  | Dave

用户预订

id | user_id | title         | start_date | end_date
------------------------------------------------------
1  | 1       | Booking One   | 1484133562 | 1484133562
2  | 1       | Booking Two   | 1484133562 | 1484133562
3  | 2       | Booking Three | 1484133562 | 1484133562

网站用户可以搜索在指定时间内进行预订的用户。因此,他们可以搜索如下日期:01/01/201705/01/2017,如果 user_id 1 在此期间进行了预订,则他们不会出现在结果。

我目前有一个查询,例如:

SELECT 
users.name, 
user_bookings.name 
FROM users 
JOIN user_bookings ON users.id = user_bookings.user_id
WHERE NOT(('$start_date' <= user_bookings.start_date) AND (user_bookings.end_date <= '$end_date')) GROUP BY users.id;

最佳答案

SELECT users.name, user_bookings.name 
FROM users 
JOIN user_bookings ON users.id = user_bookings.user_id
WHERE NOT ((DATE_FORMAT(user_bookings.start_date,'%m/%d/%Y') >= '$start_date' AND DATE_FORMAT(user_bookings.end_date,'%m/%d/%Y') <= '$end_date')) AND users.id = 1
GROUP BY users.id;

关于MySQL选择时间戳不重叠的地方,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41589879/

相关文章:

php 没有将正确的值存储到数据库中

php - 检查尺寸、宽度和高度后上传图片

mysql - 是否可以在 mysql 中的具有变量值的表中添加列?

mysql - SQL:选择A而不是B的集合

mysql - 在 MySQL 的存储过程中使用 if 语句

PHP PDO 数据库备份类

php - OpenCart 自定义模块 MySQL 错误 1064

mysql - 从 mysql 中获取 mm/dd/yy 格式的记录

mysql - 使用单个 Delete 语句删除多个表

MySQL连接问题