java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String

问题:mybatis 新版本那事件类型入参与空字符串比较抛异常
解决如下:

date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})

开发中改动mapper文件后需要重新编译发布, 由于工程比较大非常耗时, 所以为方便快速测试干脆写了一个小Java工程. 工程中用到的dao, mapper和实体类都是从工程中拷出来的, 数据库也是同一个. 但是遇到一个比较奇怪的问题
实体类中有一个属性
private Date createTime;
对应该属性数据库中定义的是
create_time datetime
mapper中该属性映射的定义

以下是mapper中对应Dao方法SQL语句

select * from user


date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})



其中date()函数只是用来把年月日时分秒的日期截取为年月日, 这个对于该异常没有任何影响
在测试类中创建实体并为其属性赋值
User user=new User();
user.setCreateTime(new SimpleDateFormat(“yyyy-MM-dd”).parse(“2016-01-18”));
然后执行查询方法dao.selectByCreateTime(user)的时候就报了java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String的错。
看样子是因为类型不符合, 但是想了想, 类型对应Oracle的date, 以及mapper中jdbcType都没问题啊. 而且完全一样的东西在原工程中是完全正常的. 后来在网上找了一下才知道, 原来这是mybatis 3.3.0中对于时间参数进行比较时的一个bug. 如果拿传入的时间类型参数与空字符串”进行对比判断则会引发异常. 所以在上面的代码中去掉该判断, 只保留非空判断就正常了

date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})

改为

date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值