首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >查询数据库以查看现在是否介于两个日期之间

查询数据库以查看现在是否介于两个日期之间
EN

Stack Overflow用户
提问于 2018-04-11 06:24:09
回答 2查看 39关注 0票数 0

我阅读了如何在两个日期( here )之间查询,但我试图做相反的事情。我有一个事件数据库,有开始和结束的日子。我正在检查now()是否介于开始日和结束日之间。

值得注意的是,我的事件是周期性的,所以我不关心这些年。为了在我的数据库中使用数据格式,我只使用2000作为一切。我有一些活动,比如圣诞节(2000-12-01到2000-12-25),独立日(2000-06-25到2000-07-04)等等。

一开始我在考虑做这样的事情:

代码语言:javascript
运行
复制
SELECT * FROM `table` WHERE MONTH(NOW()) >= MONTH(`start`) AND DATE(NOW()) >= DATE(`start`) AND MONTH(NOW()) <= MONTH(`end`) AND DATE(NOW()) <= DATE(`end`)

但后来我意识到一个重大的缺陷,这段时间跨越了好几个月。如果今天是27JUN,那么我希望独立日行能返回,但是27 >= 25,27 <= 4并不是这样。

我想看看我是否可以把现在()、开始和结束转换成一个时间戳,让我比较它们,但是我对这个想法进行了折扣,因为我可能有一些东西的开始日期是2000-12-26,而结束日期是2000-01-01 (记住我忽略了这个年份)。

是否有更好的方法来存储月份/日期对而不是日期?或者我能做些什么来修复我的数据库查询?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-04-11 06:59:23

在比较开始日期和结束日期之前,必须将目前的日期调整回2000年。如果结束日期在开始日期之前,则结束日期的年份实际上是开始日期之后的一年。试试这个:

代码语言:javascript
运行
复制
SELECT * from `table`
WHERE
(`end` >= `start` AND 
 DATE_ADD(CURDATE(), INTERVAL 2000-YEAR(CURDATE()) YEAR) 
 BETWEEN `start` AND `end`)
OR
(`end` < `start` AND 
 DATE_ADD(CURDATE(), INTERVAL 2000-YEAR(CURDATE()) YEAR) 
 BETWEEN `start` and DATE_ADD(`end`, INTERVAL 1 YEAR))

或:

代码语言:javascript
运行
复制
SELECT * from `table`
WHERE
CASE 
WHEN `end` >= `start` THEN 
DATE_ADD(CURDATE(), INTERVAL 2000-YEAR(CURDATE()) YEAR) BETWEEN `start` AND `end`
ELSE
DATE_ADD(CURDATE(), INTERVAL 2000-YEAR(CURDATE()) YEAR) BETWEEN `start` and DATE_ADD(`end`, INTERVAL 1 YEAR)
END 

使用CURDATE()而不是NOW(),因为NOW()具有不需要的时间组件。

票数 1
EN

Stack Overflow用户

发布于 2018-04-11 06:33:41

SELECT * FROM table WHERE CURDATE() between dateStart and dateEnd

dateStart是你过去的约会,dateEnd是你未来的约会

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49767909

复制
相关文章

相似问题

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