这个是我要运行的代码
这个是这段代码报的错。
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的同学们,不管是跟着老师视频来写的还是自己琢磨的,都希望大家更加细心!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)