mybatis报错:getString/getxxx not implemented for class oracle.jdbc.driver.T4CBlobAccessor

报错如下:导致原因----->当时我写了一个只有部分属性的构造函数

一.首先,你得排除你的xml文件里面的字段类型与实体与数据库里面是一致的,如果检查了没问题但是还是报错,那就继续往下看👇👇👇👇👇👇

二.走到了这里,那就得往mybatis底层里面走了:

1.通过打断点得方式可以发现,mybatis在执行查询sql后会调用实体得构造函数进行字段得映射:

大家都知道实体里默认是会有一个无参构造函数,但是当你自己写了一个显性得构造函数时,就不会自动创建无参构造函数了(除非你再写一个显性得无参构造函数);

2.然后写了一个查询部分属性的sql,比如select  update_time,name from user_info where xxxx;

但是构造函数为VO(int  value1,string value2),此时mybatis查询成功后调用构造函数进行映射,会尝试将data类型的update_time映射为int类型,如此便报错了;

3.那么造成这样的原因是什么呢,下面两张图就可以看懂了:

构造函数获取顺序为,先看无参构造函数是否存在,若不存在,则取显性构造函数,至于用哪个,则取决于你查询sql返回的字段个数与哪个构造函数个数相等,如果相等,就开始映射:

4.源码逻辑如下:

5.那如果既没有无参构造函数,有参构造函数的个数跟查询字段个数匹配不上会出现什么情况呢?

那就是如下报错:无法转换为内部表示

6.解决方法:添加一个显性无参构造方法即可!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值