Mybatis Exception Date cannot be cast to String

org.apache.ibatis.type.TypeException: 


最重要是这个提示信息:
Mybatis 不能完成参数映射


Could not set parameters for mapping: 


这个参数是cffDate

ParameterMapping{property='cffDate', 
mode=IN, javaType=class java.lang.String, 
jdbcType=null, numericScale=null, 
resultMapId='null', jdbcTypeName='null', 
expression='null'}. 


原因是类型转换异常

Cause: org.apache.ibatis.type.TypeException: 

Error setting non null for parameter 

#1 with JdbcType null . 

Try setting a different JdbcType for this parameter 

or 

a different configuration property. Cause: java.lang.ClassCastException: 


异常时不能把Date 转换成String

class java.util.Date cannot be cast to class java.lang.String 


(java.util.Date and java.lang.String are 

in module java.base of loader 'bootstrap')

当你在MyBatis中遇到`ClassCastException: java.lang.String cannot be cast to java.util.Date`这类错误,通常是因为你在尝试将字符串转换为`Date`对象,但是传入的值并不是有效的日期格式。MyBatis默认会尝试将查询结果中的字符串解析为`Date`类型,如果数据库返回的数据不是`yyyy-MM-dd`、`yyyyMMdd`等标准日期格式,或者直接是一个非日期字符串,就会抛出这个异常。 解决这个问题,你可以做以下几个步骤: 1. **检查映射文件**:确认你的SQL语句是否正确地设置了`resultType`或`resultMap`属性为`java.util.Date`,并且对应的字段值可以被正确解析为日期。 2. **设置日期转换规则**:在MyBatis的配置文件`mybatis-config.xml`中,添加`<typeHandler>`元素,自定义一个处理`String`到`Date`转换的`TypeHandler`。 ```xml <typeHandler handler="com.example.YourCustomDateTypeHandler" javaType="java.util.Date" jdbcType="DATE"/> ``` 这里,你需要创建一个实现了`org.apache.ibatis.type.TypeHandler`接口的类,处理字符串到`Date`的转换。 3. **处理输入数据**:如果你是从用户输入或其他不可靠来源获取的日期字符串,可能需要先验证其格式,再进行转换。 4. **手动转换**:在业务逻辑中,你可以捕获这个异常,并显式地使用如`SimpleDateFormat`或`DateTimeFormatter`将字符串转换为`Date`。 **相关问题--:** 1. MyBatis如何处理非日期类型的查询结果? 2. 如何在MyBatis中自定义TypeHandler? 3. 如果日期格式不固定,如何在代码层面处理这种情况?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值