原创

关于 There is no getter for property named 'id' in 'class java.lang.Integer'

在写SSM框架的时候,请求报出 There is no getter for property named 'id' in 'class java.lang.Integer'这个问题

但是实际上实体类中写了相关的方法,最后找到问题出现在Mapper接口中,

 List<User> getAllUser( Integer id);

将代码改为:

List<User> getAllUser(@Param("id") Integer id);

问题解决

 

 

 

方法2

当mapper的方法参数是基础类型且只有一个时,在mapper.xml文件中使用${}取值时,会报There is no getter for property named 'id' in 'class java.lang.Integer'异常。

解决方法

1、@Param注解


 
public AreaDict selectById(@Param("id") Integer id);

 
select * from area_dict where area_dict_id = ${id}

2、将${}换成#{}取值,#{}能防止sql注入,${}只是简单的字符串替换,#{}先进行预处理

select * from area_dict where area_dict_id = #{id}
3、通过${value}或${_parameter}取值


 
select * from area_dict where area_dict_id = ${_parameter}

select * from area_dict where area_dict_id = ${value}

正文到此结束
该篇文章的评论功能已被站长关闭
本文目录