Mybatis There is no getter for property named 'XXX' in 'class java.lang.XXX
2016-11-04 17:33
696 查看
Mybatis查询
使用Mybatis查询时,其参数可以是基本数据类型或者像Integer和String这样的简单的数据对象,也可以是复杂对象(一般是指JavaBean)或者map等,当使用基本数据类型的参数时,若这个参数的使用放在了判断条件中,如下查询语句:
sql代码:
<select id="getNameList" parameterType="String" resultType="String">
<![CDATA[
SELECT DISTINCT NAME
FROM T_PERSION
WHERE 1=1
]]>
<if test="age!=null">
AND AGE = #{age}
</if>
</select> 则可能会出现:
Errorlog代码
org.apache.ibatis.reflection.ReflectionException:There is no getter for property named 'XXX' in 'class java.lang.XXX 的异常,问题的直接原因是由于上面的parameterType是基本的简单类型而后面有判断的if条件,若没有后面的判断条件,而是:
Sql代码:
<select id="getNameList" parameterType="String" resultType="String">
<![CDATA[
SELECT DISTINCT NAME
FROM T_PERSION
WHERE 1=1
AND AGE = #{age}
]]>
</select>
则没有任何异常。
对上面的异常,网上说问题原因是Mybatis默认采用ONGL解析参数,所以会自动采用对象树的形式获取传入的变量值,解决方法有两个:
1.将参数名(上面的例子为‘age’)替换为"_parameter" ,即:
Sql代码:
<select id="getNameList" parameterType="String" resultType="String">
<![CDATA[
SELECT DISTINCT NAME
FROM T_PERSION
WHERE 1=1
]]>
<if test="_parameter!=null">
AND AGE = #{_parameter}
</if>
</select> 2,在接口中定义方法时 增加“@Param("参数名")”
标记,例如:
Sql代码:
List<String> getNameList(@Param("age")String age);
使用Mybatis查询时,其参数可以是基本数据类型或者像Integer和String这样的简单的数据对象,也可以是复杂对象(一般是指JavaBean)或者map等,当使用基本数据类型的参数时,若这个参数的使用放在了判断条件中,如下查询语句:
sql代码:
<select id="getNameList" parameterType="String" resultType="String">
<![CDATA[
SELECT DISTINCT NAME
FROM T_PERSION
WHERE 1=1
]]>
<if test="age!=null">
AND AGE = #{age}
</if>
</select> 则可能会出现:
Errorlog代码
org.apache.ibatis.reflection.ReflectionException:There is no getter for property named 'XXX' in 'class java.lang.XXX 的异常,问题的直接原因是由于上面的parameterType是基本的简单类型而后面有判断的if条件,若没有后面的判断条件,而是:
Sql代码:
<select id="getNameList" parameterType="String" resultType="String">
<![CDATA[
SELECT DISTINCT NAME
FROM T_PERSION
WHERE 1=1
AND AGE = #{age}
]]>
</select>
则没有任何异常。
对上面的异常,网上说问题原因是Mybatis默认采用ONGL解析参数,所以会自动采用对象树的形式获取传入的变量值,解决方法有两个:
1.将参数名(上面的例子为‘age’)替换为"_parameter" ,即:
Sql代码:
<select id="getNameList" parameterType="String" resultType="String">
<![CDATA[
SELECT DISTINCT NAME
FROM T_PERSION
WHERE 1=1
]]>
<if test="_parameter!=null">
AND AGE = #{_parameter}
</if>
</select> 2,在接口中定义方法时 增加“@Param("参数名")”
标记,例如:
Sql代码:
List<String> getNameList(@Param("age")String age);
相关文章推荐
- MyBatis:There is no getter for property named 'XXX' in 'class java.lang.XXXX'
- Mybatis异常There is no getter for property named 'XXX' in 'class java.lang.String
- MyBatis报错:There is no getter for property named 'xxx' in 'class java.lang.String'
- MyBatis There is no getter for property named 'xxx' in 'class java.lang.String'
- 关于Mybatis "There is no getter for property named 'XXX' in class java.lang.String"的问题
- Mybatis-There is no getter for property named 'XXX' in 'class java.lang.String'解决办法
- MyBatis There is no getter for property named 'xxx' in 'class java.lang.String'
- mybatis:There is no getter for property named 'xxx' in 'class java.lang.String'
- Mybatis异常There is no getter for property named 'XXX' in 'class java.lang.String'
- mybatis 基本类型的if条件判断问题 There is no getter for property named 'xxx' in 'class Java.lang.Integer'
- mybatis错误:There is no getter for property named 'xxx' in 'class java.lang.String'
- Mybatis异常There is no getter for property named 'XXX' in 'class java.lang.String'
- mybatis出现There is no getter for property named 'XXX' in 'class java.lang.String'错误
- mybatis String的if条件判断问题 There is no getter for property named 'xxx' in 'class Java.lang.Integer'
- Mybatis找不到参数错误:There is no getter for property named 'categoryId' in 'class java.lang.Integer'。
- Mybatis报There is no getter for property named 'name' in 'class java.lang.String'错误
- Mybatis问题:There is no getter for property named 'VALUE' in 'class java.lang.String'
- mybatis There is no getter for property named 'xx' in 'class java.lang.String
- MyBatis错误:There is no getter for property named 'paramSql' in 'class java.lang.String'
- Mybatis-There is no getter for property named 'id' in 'class java.lang.String'