原来是:
<if test="params.timeFrom != '' and params.timeFrom !=null"> AND createTime >= #{params.timeFrom} </if> <if test="params.timeTo != '' and params.timeTo !=null"> AND createTime <= #{params.timeTo} </if>
改成:
<if test="params.timeFrom !=null"> AND createTime >= #{params.timeFrom} </if> <if test="params.timeTo !=null"> AND createTime <= #{params.timeTo} </if>
即可。
参考: http://blog.csdn.net/wanghailong_qd/article/details/50673144 原来这是mybatis 3.3.0中对于时间参数进行比较时的一个bug. 如果拿传入的时间类型参数与空字符串''进行对比判断则会引发异常. 所以在上面的代码中去该该判断, 只保留非空判断就正常了
|