Could not set property ‘xxx‘ of ‘class ‘xxx‘ with value ‘xxx‘,Cause: java.lang.IllegalArgumentExcept

Could not set property ‘xxx‘ of ‘class ‘xxx‘ with value ‘xxx‘,Cause: java.lang.IllegalArgumentExcept,第1张

 这个是我要运行的代码

 

 这个是这段代码报的错。

Cause: org.apache.ibatis.reflection.ReflectionException:

Could not set property 'd' of 'class com.mypro.entity.build'

with value 'drom{houseNb=418, floor=4, direction='south', buid=4}'

Cause: java.lang.IllegalArgumentException: argument type mismatch

错误的意思是,无法给d设置属性,因为参数类型不匹配。

我是对照着老师的视频来写,因为是先看完视频再去写,导致一下没转过弯来。

这个是我要用的注释型查询,注意看其中的 javaType=drom.class

   @Select("select * from build")

   @Results(id = "buildMap",value = {
           @Result(id = true,property = "buid",column = "buid",javaType = Integer.class),

           @Result(property = "d",column = "buid",javaType = drom.class,
           many=@Many(select = "com.mypro.mapper.dromMapper.querySingle",fetchType = FetchType.EAGER))
   })
   public  List queryAll();

这样写其实没错,但是我要查询的是多个数据,而且我在build类中将d设置的是一个集合型

这因为我设置的是集合型,所以 javaType=drom.class是一个错误的写法

应该写成javaType=List.class,写成集合型。所以会显示参数类型不匹配的报错。

其实这种类型不匹配的错误还会有其他报错,这个报错是基于最上面所运行的代码不一致。

这是另外一个代码,我是在上面代码运行错误的情况下,尝试运行其他查询

 这是报的错

Cause: org.apache.ibatis.executor.ExecutorException:

Statement returned more than one row, where no more than one was expected.

报错的内容为,语句返回了多行,其中不应该超过一行

然后我也在疑惑,为什么我build类中设置的是List数组,我也想要它返回多行数据给我,但是它还报错。

答案就是上面的内容。

我已经醉了~~~~,已经是第二次犯这个错了,希望没下次了!!!

希望各位正在学习mybatis的同学们,不管是跟着老师视频来写的还是自己琢磨的,都希望大家更加细心!

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/875882.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-13
下一篇 2022-05-13

发表评论

登录后才能评论

评论列表(0条)

保存