![cover](https://img-blog.csdnimg.cn/20210604123041842.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L05laUhhbjIwMjA=,size_16,color_FFFFFF,t_70)
解决MyBatis的报错 There is no getter for property named ‘*‘ in ‘class java.lang.String‘
报错样式:核心问题就是这一句:
![](https://csdnimg.cn/release/devpress/public/img/ic-book.4f347164.png)
一键AI生成摘要,助你高效阅读
问答
·
报错样式:
Mapper的内容:
核心问题就是这一句: There is no getter for property named '*' in 'class java.lang.String'
意思大概就是: 在“类java.lang.String”中没有名为“*”的属性的getter。
前言:
一开始看到这个问题我是很蒙蔽的,按理说,我传值要求的是 parameterType="string" ,在标签里面使用任意名字即可调用传进来的值,但是为什么在test里面使用就报错呢?
后来研究发现了两个解决方案
方案一:
在test中使用 value 这个固定的参数名即可调用传进来的值
方案二:
在test中使用 _parameter 这个固定的参数名即可调用传进来的值
解决原因:
- SQL在 test 条件中使用传递参数要放在实体对象中,不然会报错找不到对象
- 如果不放在实体对象中传输,就在test对比中使用_parameter或者value
- _parameter,value代表传进来的参数,如果传进来的参数是多个,那个_parameter代表get(0)第一个
更多推荐
所有评论(0)