栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

 这个是我要运行的代码

 

 这个是这段代码报的错。

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的同学们,不管是跟着老师视频来写的还是自己琢磨的,都希望大家更加细心!

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/865642.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号