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

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

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

纵有千千星晚   2021-09-05 我要评论
想了解mysql判断当前时间是否在开始与结束时间之间且开始与结束时间允许为空的相关内容吗,纵有千千星晚在本文为您仔细讲解mysql判断当前时间是否在开始与结束时间之间的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:mysql判断当前时间,mysql,当前时间,下面大家一起来学习吧。

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

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

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

SELECT * FROM 
表名
WHERE 1=1 
and(start_time is null or start_time<now()) 
and(end_time is null or end_time>now())

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

在这里插入图片描述

<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>

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们