微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MYSQL:按日期获取多天活动

如何解决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 举报,一经查实,本站将立刻删除。