mybatis异常invalid comparison: java.util.Date and java.lang.String
2023-06-13 09:12:26 时间
大家好,又见面了,我是你们的朋友全栈君。
开发中改动mapper文件后需要重新编译发布, 由于工程比较大非常耗时, 所以为方便快速测试干脆写了一个小java工程. 工程中用到的dao, mapper和实体类都是从工程中拷出来的, 数据库也是同一个. 但是遇到一个比较奇怪的问题
实体类中有一个属性
private Date createTime;
对应该属性数据库中定义的是
create_time datetime
mapper中该属性映射的定义
<result column="create_time" property="createTime" jdbcType="TIMESTAMP" />
以下是mapper中对应Dao方法SQL语句
<select id="selectByCreateTime" resultMap="userMap">
select * from user
<where>
<if test="createTime != null and createTime !='' " >
date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
</if>
</where>
</select>
其中date()函数只是用来把年月日时分秒的日期截取为年月日, 这个对于该异常没有任何影响
在测试类中创建实体并为其属性赋值
User user=new User();
user.setCreateTime(new SimpleDateFormat("yyyy-MM-dd").parse("2016-01-18"));
然后执行查询方法dao.selectByCreateTime(user)的时候就报错了
Exception in thread "main" 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.$Proxy0.selectByCreateTime(Unknown Source)
at mybatis.Test.buyerInfoTimeTest(Test.java:53)
at mybatis.Test.main(Test.java:39)
Caused by: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
at org.apache.ibatis.ognl.OgnlOps.compareWithConversion(OgnlOps.java:92)
at org.apache.ibatis.ognl.OgnlOps.isEqual(OgnlOps.java:142)
at org.apache.ibatis.ognl.OgnlOps.equal(OgnlOps.java:794)
at org.apache.ibatis.ognl.ASTNotEq.getValueBody(ASTNotEq.java:53)
at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)
at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)
at org.apache.ibatis.ognl.ASTAnd.getValueBody(ASTAnd.java:61)
at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)
at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)
at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:494)
at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:458)
at org.apache.ibatis.scripting.xmltags.OgnlCache.getValue(OgnlCache.java:44)
at org.apache.ibatis.scripting.xmltags.ExpressionEvaluator.evaluateBoolean(ExpressionEvaluator.java:32)
at org.apache.ibatis.scripting.xmltags.IfSqlNode.apply(IfSqlNode.java:34)
at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)
at org.apache.ibatis.scripting.xmltags.TrimSqlNode.apply(TrimSqlNode.java:55)
at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)
at org.apache.ibatis.scripting.xmltags.DynamicSqlSource.getBoundSql(DynamicSqlSource.java:41)
at org.apache.ibatis.mapping.MappedStatement.getBoundSql(MappedStatement.java:280)
at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:80)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:120)
... 7 more
看样子是因为类型不符合, 但是想了想, Date类型对应MySQL的datetime, 以及mapper中jdbcType都没问题啊. 而且完全一样的东西在原工程中是完全正常的. 既然都是一样的代码, 那就找找俩工程有啥不一样的吧
首先是mysql jar版本不同. 换成原工程中的版本也无效. 然后是mybatis jar版本不一样, 换成原工程中的版本问题就解决了!
原工程中配置的是mybatis-3.2.8, 而我测试工程中用的是mybatis-3.3.0.后来在网上找了一下才知道, 原来这是mybatis 3.3.0中对于时间参数进行比较时的一个bug. 如果拿传入的时间类型参数与空字符串”进行对比判断则会引发异常. 所以在上面的代码中去该该判断, 只保留非空判断就正常了
<if test="createTime != null and createTime !='' " >
date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
</if>
改为
<if test="createTime != null">
date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
</if>
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/160372.html原文链接:https://javaforall.cn
相关文章
- 女生学java_Java Server Pages
- Java反射——内省(Introspector)以及BeanUtils内省框架
- java long string 转换_Java long 转成 String的实现[通俗易懂]
- java helloworld源代码_Java Hello World源代码剖析
- java工具类-Java对象转换成Map
- 手机java程序_2020年最流行的Java开发技术
- java 堆栈的声明_Java 堆栈[通俗易懂]
- Java双向队列Deque栈与队列
- java setproperty 未生效_Java System类setProperty()方法及示例[通俗易懂]
- java递归和迭代_Java中的迭代与递归
- 【说站】java局部变量表的介绍
- java swing图形化界面_javagui界面设计
- java switch case 语句
- JAVA遍历数组的三种方法_java遍历object数组
- Java跨平台你真的理解对了吗?
- Java之浅克隆和深克隆详解编程语言
- Java 连接 MySQL 数据库简易实现(java连mysql)
- 标题:Linux下发布Java:开创新纪元(linux发布java)
- MySQL与Java的无缝互联(java与mysql连接)
- Java获取当前时间详解编程语言
- 【Java】为什么重写equals一定要重写hashcode详解编程语言
- 服务器实现Java远程访问Linux服务器(java远程linux)
- 失效Java应用Redis实现缓存失效的优化(redisjava过期)
- 策略探索Java操作Redis过期策略(redisjava过期)
- 使用Java远程控制Linux 实现简单、高效的服务器管理(java控制linux)
- Linux下Java命令:简介与基本用法(linux下java命令)
- Redis中使用Java快速实现自增(redis自增 java)