BUG:invalid comparison: java.util.Date and java.lang.String
实体类日期Date格式;
页面上字符串;
数据库date类型;
<result column="pro_time" property="proTime"
jdbcType="DATE" />
不明白为啥date类型不能直接入库?
查了一堆资料,
有人说Controller加上下列代码,结果然并栾。。
@InitBinder
public void initBinder(WebDataBinder binder) {
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
dateFormat.setLenient(false);
binder.registerCustomEditor(Date.class, new CustomDateEditor(dateFormat, false));
}
后来发现,是不是版本原因造成bug,但是我这个mybatis3.4.1最新的,难道更换版本?
终于找到解决办法,这是由于mybatis日期类型比较时出现问题,date类型不能与字符串类型比较,原因不知。这就找到了问题。xml文件中,判断是否为空时,与null和‘’比较导致问题。更改后,解决bug。
<if test="Time!=null and test="Time!=''">
将字符串类型删除即可
PS:我恨这种由于版本原因导致的bug,根本无从查起。或许我还是太年轻了!!!
参考资料:
http://mvnrepository.com/artifact/org.mybatis/mybatis
http://stackoverflow.com/questions/30163144/datetimeformatpattern-yyyy-mm-dd-with-spring-mvc-rest-service-gives-error
http://www.oschina.net/question/252854_2144935
http://blog.csdn.net/wanghailong_qd/article/details/50673144