介绍
这篇文章主要讲解了“mysql开始与结束时间允许为空的条件下怎么判断当前时间是否在开始与结束时间之间”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql开始与结束时间允许为空的条件下怎么判断当前时间是否在开始与结束时间之间”吧!
<编辑类="目录">目录编辑>- <李>
需求:查询进行中的活动数据
李> <李>下面sql则查询的是满足以上四种需求的结果集,达标题需求
李>需求:查询进行中的活动数据
进行中一共有以下几种情况:
1。开始时间为空,结束时间为空,此结果数据将永远为进行中的数据
2。开始时间为空,结束时间不为空,则当前时间在结束时间之前,为进行中的数据
3。开始时间不为空,结束时间为空,则当前时间在开始时间之后,为进行中的数据
4。开始时间不为空,结束时间不为空,则当前时间在开始与结束时间段之内的数据为进行中数据
下面sql则查询的是满足以上四种需求的结果集,达标题需求
SELECT *,得到 表名 WHERE 1=1, 和(start_time is  null 或是start_time<现在()), 和(end_time is  null 或是end_time>现在())
mybatis写法,开始时间与结束时间传入参数允许为空
如图所示:
& lt; if 测试=皉ecord.startDate !=, null 以及record.startDate !=, & # 39; & # 39;,趁机record.endDate !=, null 以及record.endDate !=, & # 39; & # 39;,“比; ,,,,以及id 在信息 ,,,,,(得到rht_product_price 获select id ; where 1=1 ,,,,,& lt; if 测试=皉ecord.startDate !=, null 以及record.startDate !=, & # 39; & # 39;“比; ,,,,,,,以及,start_date , lt;=, # {record.startDate jdbcType=VARCHAR} ,,,,,& lt;/if> ,,,,,& lt; if 测试=皉ecord.endDate !=, null 以及record.endDate !=, & # 39; & # 39;“比; ,,,,,,,以及end_date 和gt;=, # {record.endDate jdbcType=VARCHAR} ,,,,,& lt;/if> ,,,,,) ,,,& lt;/if>
感谢各位的阅读,以上就是“mysql开始与结束时间允许为空的条件下怎么判断当前时间是否在开始与结束时间之间”的内容了,经过本文的学习后,相信大家对mysql开始与结束时间允许为空的条件下怎么判断当前时间是否在开始与结束时间之间这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!