在我的数据库中,我有一个带有签入日期的列和一个带有签出日期的列。我需要选择每一行有一个签入日期<= 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。我遗漏了什么?还是有更简单的方法来完成我的目标?
发布于 2017-09-11 19:29: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 str_to_date('7/30/2017','%d/%m/%Y')
between cast(checkin as date) AND cast(checkout as date) 发布于 2017-09-11 19:46:15
试着像这样
SELECT *
FROM `v_reservation_records`
WHERE DATE_FORMAT(checkin, '%m/%d/%Y') between '7/30/2017'
AND '7/30/2017'https://stackoverflow.com/questions/46163083
复制相似问题