如何解决MYSQL:按日期获取多天活动
title | start_date | end_date
---------------------------------------------------
Event 1 | 2020-09-01 13:00:00 | 2020-09-01 17:30:00
Event 2 | 2020-09-02 20:00:00 | 2020-09-02 21:00:00
Event 3 | 2020-09-01 07:00:00 | 2020-09-05 18:30:00
例如:
getEvents('2020-09-01 00:00:00');
将返回事件1 和事件3 。
getEvents('2020-09-02 00:00:00');
将返回事件2 和事件3 。
getEvents('2020-09-04 00:00:00');
将返回事件3 。
什么是实现此功能的理想查询?我目前面临的主要麻烦是试图通过多日活动验证输入日期。
请告知。
解决方法
您想要与搜索日期重叠的行。
说您想要9月1日的活动,您可以去
select t.*
from mytable t
where t.end_date >= '2020-09-01' and t.start_date < '2020-09-02'
也许您将传递搜索日期作为参数:
select t.*
from mytable t
where t.end_date >= ? and t.start_date < ? + interval 1 day
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。