Mybatis_ReflectionException:There is no getter for property named 'distinct' in 'class tk.mybatis

本文详细解析了在使用MyBatis框架时遇到的ReflectionException异常,具体为在Service层调用selectByExample方法时出现的错误。文章指出错误原因为参数类型不匹配,并提供了正确的解决方案,即应传递Example对象而非其他类型。

1. 发生异常的背景
 情景:
我在Service层里面继承了通用mapper接口,其中有一个方法是selectByExample,然后在调用的时候报了一个org.apache.ibatis.reflection.ReflectionException错误,详情如下:

// 所报的主要异常如下:
org.mybatis.spring.MyBatisSystemException: 
	nested exception is org.apache.ibatis.reflection.ReflectionException: 
	There is no getter for property named 'distinct' in 'class tk.mybatis.mapper.entity.Example$Criteria'
	at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:79)
	at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:447)
	at com.sun.proxy.$Proxy136.selectList(Unknown Source)
	at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:231)
	at org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:137)
	at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:75)
	at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)
	at com.sun.proxy.$Proxy164.selectByExample(Unknown Source)

 我所调用方法如下:
所用方法

 
2. 原因以及解决方法
因为我所传参数不对,不管这边传泛型T还是传criteria,都会报该错误。

  • 解决方法:解决方法
    因为自己粗心,写快了。mapper.selectByExample()方法里面应该传入的参数是example,而非其他的。作为惩罚,写到博客里,加深自己的印象,如果能帮助别人遇到这个问题而不知道怎么解决,便再好不过了。
`org.apache.ibatis.reflection.ReflectionException: there is no getter for property named null in class a` 这个错误通常意味着 MyBatis 在尝试访问类 `a` 中某个属性的 getter 方法时,找不到对应的方法。以下是一些可能的解决方法: ### 检查属性名和 getter 方法 确保 MyBatis SQL 映射文件(如 XML 文件)中引用的属性名在类 `a` 中存在,并且有对应的 getter 方法。例如,如果 SQL 映射文件中有 `${propertyName}` 这样的引用,那么类 `a` 中应该有 `getPropertyName()` 方法。 ```java // 示例类 a public class A { private String propertyName; // 确保有对应的 getter 方法 public String getPropertyName() { return propertyName; } public void setPropertyName(String propertyName) { this.propertyName = propertyName; } } ``` ### 检查 SQL 映射文件 检查 SQL 映射文件中属性名的拼写是否正确,包括大小写。MyBatis 是区分大小写的。 ```xml <select id="selectSomething" parameterType="a" resultType="java.lang.String"> SELECT some_column FROM some_table WHERE some_condition = #{propertyName} </select> ``` ### 检查参数类型 确保 SQL 映射文件中指定的 `parameterType` 与实际传入的对象类型一致。 ```xml <select id="selectSomething" parameterType="com.example.A" resultType="java.lang.String"> SELECT some_column FROM some_table WHERE some_condition = #{propertyName} </select> ``` ### 检查注解 如果使用注解方式配置 MyBatis,确保注解中引用的属性名正确。 ```java @Select("SELECT some_column FROM some_table WHERE some_condition = #{propertyName}") String selectSomething(A a); ``` ### 检查 MyBatis 版本兼容性 确保使用的 MyBatis 版本与项目中的其他依赖兼容,有时版本不兼容也可能导致此类问题。
评论 13
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值