我阅读了如何在两个日期( here )之间查询,但我试图做相反的事情。我有一个事件数据库,有开始和结束的日子。我正在检查now()是否介于开始日和结束日之间。
值得注意的是,我的事件是周期性的,所以我不关心这些年。为了在我的数据库中使用数据格式,我只使用2000作为一切。我有一些活动,比如圣诞节(2000-12-01到2000-12-25),独立日(2000-06-25到2000-07-04)等等。
一开始我在考虑做这样的事情:
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 (记住我忽略了这个年份)。
是否有更好的方法来存储月份/日期对而不是日期?或者我能做些什么来修复我的数据库查询?
发布于 2018-04-11 06:59:23
在比较开始日期和结束日期之前,必须将目前的日期调整回2000年。如果结束日期在开始日期之前,则结束日期的年份实际上是开始日期之后的一年。试试这个:
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))或:
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()具有不需要的时间组件。
发布于 2018-04-11 06:33:41
SELECT * FROM table WHERE CURDATE() between dateStart and dateEnd
dateStart是你过去的约会,dateEnd是你未来的约会
https://stackoverflow.com/questions/49767909
复制相似问题