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

柔光的暖阳◎ 2023-01-07 04:59 292阅读 0赞

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

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

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

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

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

在这里插入图片描述

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

发表评论

表情:
评论列表 (有 0 条评论,292人围观)

还没有评论,来说两句吧...

相关阅读