Mybatis中如何查询时间段内的数据

本文介绍了在Mybatis中遇到查询时间段内数据时,如何处理参数为空导致的SQL执行问题。通过分析demo1和demo2的问题,提出了将条件拆分及使用<![CDATA[ ]]>或MySQL特有写法的解决方案。
摘要由CSDN通过智能技术生成

前面是遇到的问题,可以直接跳过看最后解决方法的最后一个demo

问题:

这样的写法会增加许多不必要的逻辑判断

  • demo1

当其中有一个参数为空的时候,这个sql就不会被执行

<if test="beginDate != null and beginDate != '' and endDate != null and endDate != ''">
            stock_bill.bill_date between #{beginDate} and #{endDate}
 </if>
  • demo2

此时我们将and改为or,但当一个参数为空时,会报错

 <if test="beginDate != null and beginDate != '' or endDate != null and endDate != ''">
          AND stock_bill.bill_date between #{beginDate} and #{endDate}
 </if>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值