使用MySQL,如果两个日期在不同的列中,如何选择两个日期之间的数据

使用MySQL,如果两个日期在不同的列中,如何选择两个日期之间的数据,mysql,date,Mysql,Date,在我的数据库中,有一列带有签入日期,另一列带有签出日期。我需要选择登记日期为2017年7月30日的每一行 这是我现在拥有的代码: SELECT * FROM `v_reservation_records` WHERE cast(checkin as date) <= '7/30/2017' AND cast(checkout as date) >= '7/30/2017' 当我运行此查询时,我没有得到任何结果,但我知道我的登记日期等于2017年7月30日。我错过了什么?或者有

在我的数据库中,有一列带有签入日期,另一列带有签出日期。我需要选择登记日期为2017年7月30日的每一行

这是我现在拥有的代码:

SELECT * 
FROM `v_reservation_records` 
WHERE cast(checkin as date) <= '7/30/2017' 
AND cast(checkout as date) >= '7/30/2017'

当我运行此查询时,我没有得到任何结果,但我知道我的登记日期等于2017年7月30日。我错过了什么?或者有更简单的方法来实现我的目标吗?

假设您正在为日期设定有效值
您还应该正确地将文本转换为日期

SELECT * 
FROM `v_reservation_records` 
WHERE cast(checkin as date) <= str_to_date('7/30/2017' , '%d/%m/%Y')
AND cast(checkout as date) >= str_to_date('7/30/2017' , '%d/%m/%Y')
像这样试试

SELECT * 
FROM `v_reservation_records` 
WHERE DATE_FORMAT(checkin, '%m/%d/%Y') between '7/30/2017' 
AND '7/30/2017'

列的数据类型是什么?数据类型是日期。然后只使用
'2017-07-30'
而不是
'7/30/2017'
。并且不强制转换日期到日期。
SELECT*FROM v_reservation_records,其中checkin='2017-30-7'
运行此操作仍然不会返回任何结果。如果你是对的,看起来我有格式问题,而不是编码问题。:)这不是一个好主意,因为它破坏了使用索引的可能性。只需使用规范的YYYY-MM-DD格式的日期值。这不起作用,因为签出日期不能保证是我正在搜索的日期。事实证明,您的第二个答案解决了问题。谢谢@Paul Spiegel,也感谢您的故障排除!
SELECT * 
FROM `v_reservation_records` 
WHERE str_to_date('7/30/2017','%d/%m/%Y') 
        between cast(checkin as date) AND cast(checkout as date) 
SELECT * 
FROM `v_reservation_records` 
WHERE DATE_FORMAT(checkin, '%m/%d/%Y') between '7/30/2017' 
AND '7/30/2017'