mysql判断当前时间是否在开始与结束时间之间且开始与结束时间允许为空

吾爱主题 阅读:156 2024-04-02 08:05:22 评论:0

需求:查询进行中的活动数据

进行中一共有以下几种情况:
1.开始时间为空,结束时间为空, 此结果数据将永远为进行中的数据
2.开始时间为空,结束时间不为空,则当前时间在结束时间之前,为进行中的数据
3.开始时间不为空,结束时间为空,则当前时间在开始时间之后,为进行中的数据
4.开始时间不为空,结束时间不为空,则当前时间在开始与结束时间段之内的数据为进行中数据

下面sql则查询的是满足以上四种需求的结果集,达标题需求

?
1 2 3 4 5 SELECT * FROM 表名 WHERE 1=1 and (start_time is null or start_time<now()) and (end_time is null or end_time>now())

mybatis写法,开始时间与结束时间传入参数允许为空
如图所示:

?
1 2 3 4 5 6 7 8 9 10 11 < if test= "record.startDate != null and record.startDate != '' or record.endDate != null and record.endDate != '' " >        AND id in        (select id from rht_product_price where 1 = 1        < if test= "record.startDate != null and record.startDate != ''" >          and  start_date &lt;= #{record.startDate,jdbcType=VARCHAR}        </ if >        < if test= "record.endDate!= null and record.endDate != ''" >          and end_date &gt;= #{record.endDate,jdbcType=VARCHAR}        </ if >        )      </ if >

到此这篇关于mysql判断当前时间是否在开始与结束时间之间且开始与结束时间允许为空的文章就介绍到这了,更多相关mysql判断当前时间是否在开始与结束时间之间内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_44980116/article/details/112677751

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容