首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用MySQL,如果日期在单独的列中,如何在两个日期之间选择数据

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

Stack Overflow用户
提问于 2017-09-11 19:26:40
回答 2查看 153关注 0票数 0

在我的数据库中,我有一个带有签入日期的列和一个带有签出日期的列。我需要选择每一行有一个签入日期<= 7/30/2017和退房日期是>= 7/30/2017。

这是我现在的代码:

代码语言:javascript
复制
SELECT * 
FROM `v_reservation_records` 
WHERE cast(checkin as date) <= '7/30/2017' 
AND cast(checkout as date) >= '7/30/2017'

下面是DB的一个示例日期:

代码语言:javascript
复制
2018-09-18

当我运行这个查询时,我不会得到任何结果,但我知道我有一个签入日期等于7/30/2017。我遗漏了什么?还是有更简单的方法来完成我的目标?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-09-11 19:29:30

假设您正在为日期强制转换有效值

您也应该正确地转换日期的字面值。

代码语言:javascript
复制
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')

你也可以在

代码语言:javascript
复制
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
EN

Stack Overflow用户

发布于 2017-09-11 19:46:15

试着像这样

代码语言:javascript
复制
SELECT * 
FROM `v_reservation_records` 
WHERE DATE_FORMAT(checkin, '%m/%d/%Y') between '7/30/2017' 
AND '7/30/2017'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46163083

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档