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

时间:2017-09-11 19:26:41

标签: mysql date

在我的数据库中,我有一个包含签入日期的列和一个包含签出日期的列。我需要选择每个办理入住日期< = 7/30/2017并且退房日期为> = 7/30/2017的行。

这是我现在的代码:

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

以下是来自DB的示例日期:

2018-09-18

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

2 个答案:

答案 0 :(得分:1)

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

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 str_to_date('7/30/2017','%d/%m/%Y') 
        between cast(checkin as date) AND cast(checkout as date) 

答案 1 :(得分:0)

试试这个

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