org.apache.ibatis.exceptions.PersistenceException:
### Error querying database. Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
### Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:122)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:113)
at org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:122)
at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:64)
at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)
at com.sun.proxy.$Proxy6.getValuesById(Unknown Source)
原因:
mapper文件中的语法问题:
<if test="date !=null and date !=''"> AND <![CDATA[ DATE_FORMAT(date,'%Y-%m-%d')= DATE_FORMAT(#{date},'%Y-%m-%d')]]> </if>
这是mybatis 3.3.0中对于时间参数进行比较时的一个改变,拿传入的时间类型参数与空字符串‘’进行对比判断会引发异常。
所以在上面的代码中只保留非空判断就正常了。
<if test="date !=null ">