解决Mybatis报错:org.apache.ibatis.reflection.ReflectionException: There is no getter for property named问题

 更新时间:2025年01月15日 09:52:25   作者:Recently 祝祝  
文章主要讨论了在使用MyBatis进行数据库操作时遇到的几个常见问题及其解决方法,首先,文章指出如果DTO类中没有定义getter和setter方法,会导致反射异常,解决方法是使用Lombok的@Data注解自动生成这些方法

错误提示

服务器处理发生异常:

nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named ‘userTaskqueryDTO’ in ‘class com.lz.platform.trauma.api.interfaces.dto.task.UserTaskqueryDTO’

解决方式

可能错误原因一

解决方法一:

DTO没有写getter/setter方法,需要添加上。SpringBoot在DTO上加@Data

@Data是一个Lombok提供的注解,可以自动为Java类生成一些常用的方法,包括getter、setter、toString、equals、hashCode等方法,从而简化Java类的编写。

使用@Data注解可以让代码更加简洁,提高开发效率。

@Data
@ApiModel(value = "模糊查询列表")
public class UserTaskqueryDTO implements Serializable {
    private String idno;

    private String  Code;

    private String keyWord;
}

可能错误原因二

解决方法二:

DAO文件上没有加上注入方法@Repository

DAO文件上需要加上@Repository

@Repository是Spring框架中的一个注解,用于标识一个类作为数据访问对象(DAO)的组件。它的作用是将DAO层的Bean标记为Spring容器中的Bean,并自动执行Bean的注册、依赖注入等操作。

可能错误原因三

解决方法三:

JAVA中Mapper文件不识别#{dto.propertyName}语法,将dto.去掉

Mapper文件中方法DTO注入不能带上DTO名称。

错误Mapper:

 <select id="queryUserTraumaTaskList" resultType="com.lz.task.TraumaTask"  parameterType="com.lz.task.UserTaskqueryDTO">
        select * from   task t where 1=1
        <if test=" userTaskqueryDTO.no != null and  userTaskqueryDTO.no != ''">
            and t.NO = #{userTaskqueryDTO.no}
        </if>

        <if test="userTaskqueryDTO.keyWord != null and userTaskqueryDTO.keyWord !=''">
            and ( t.STERNO like concat( concat('%',#{userTaskqueryDTO.keyWord}),'%') or
            t.NAME like concat( concat('%',#{userTaskqueryDTO.keyWord}),'%') or
            t.IClass like concat( concat('%',#{userTaskqueryDTO.keyWord}),'%'))
        </if>

        order by t.date desc
    </select>

按照上边的写法会出现报错: 

服务器处理发生异常:nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named ‘userTaskqueryDTO’ in ‘class com.lz.platform.trauma.api.interfaces.dto.task.UserTaskqueryDTO’

下边的写法才是正确的写法: 

把DTO去掉之后,报错就消失了,加了DTO系统读取不到,去掉之后句好了

  <select id="queryUserTraumaTaskList" resultType="com.lz.task.TraumaTask"  parameterType="com.lz.task.UserTaskqueryDTO">
        select * from   task t where 1=1
        <if test=" no != null and  no != ''">
            and t.NO = #{no}
        </if>

        <if test="keyWord != null and keyWord !=''">
            and ( t.STERNO like concat( concat('%',#{keyWord}),'%') or
            t.NAME like concat( concat('%',#{keyWord}),'%') or
            t.IClass like concat( concat('%',#{keyWord}),'%'))
        </if>

        order by t.date desc
    </select>

错误原因

在Mapper文件中,使用DTO(Data Transfer Object)来传递数据,可以将数据从Java代码传输到数据库,也可以将数据从数据库传输到Java代码。

通常情况下,我们将DTO中的属性名与数据库表的列名进行对应,以便在Mapper文件中使用这些属性来构建SQL语句。

  • 在使用DTO的属性名填充Mapper文件数据时,不需要在属性名前面添加DTO名称。这是因为DTO通常是一个Java类,而不是一个数据库表,它的属性名称是在Java类中定义的,而不是在数据库表中定义的。
  • 在Mapper文件中,我们使用#{propertyName}来引用DTO的属性。如果我们在属性名前面添加了DTO名称,例如#{dto.propertyName},则会导致语法错误,因为Mapper文件不能识别这个语法。

因此,在使用DTO的属性名填充Mapper文件数据时,应该只使用属性名本身,而不需要添加DTO名称。

例如,如果DTO中有一个属性名为id,我们可以在Mapper文件中使用#{id}来引用这个属性,而不需要使用#{dto.id}。

可能错误原因四

解决方法四:

sql语句中的属性名称,跟接收,或者入参的属性名称不一致

例如:我传进来的参数名称为tmID,但是我sql语句里边写的确是tmhosID

把属性名称改为一致就可以了

注意:

  • 出参和入参的类型不要弄错了
  • 出参是一个list的话,resultType放的是list参数的类型。
  • 例如:出参List《TraumaTask》 ,resultType放的就是TraumaTask路径
  • 出参List《String 》,resultType放的就是java,util.lang

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 使用linux部署Spring Boot程序

    使用linux部署Spring Boot程序

    springboot程序在linux服务器上应该怎么部署?这次就分享下linux下如何正确部署springboot程序,感兴趣的朋友一起看看吧
    2018-01-01
  • MyBatis中的JdbcType映射使用介绍

    MyBatis中的JdbcType映射使用介绍

    这篇文章主要介绍了MyBatis中的JdbcType映射使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • java.io.File的renameTo方法移动文件失败的解决方案

    java.io.File的renameTo方法移动文件失败的解决方案

    这篇文章主要介绍了java.io.File的renameTo方法移动文件失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • ByteArrayOutputStream与InputStream互相转换方式

    ByteArrayOutputStream与InputStream互相转换方式

    这篇文章主要介绍了ByteArrayOutputStream与InputStream互相转换方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java实现单位换算功能

    Java实现单位换算功能

    这篇文章主要为大家详细介绍了Java实现单位换算功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • 浅谈java Properties类的使用基础

    浅谈java Properties类的使用基础

    下面小编就为大家分享一篇浅谈java Properties类的使用基础,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • SpringMVC上传文件的两种方法

    SpringMVC上传文件的两种方法

    这篇文章主要为大家详细介绍了SpringMVC上传文件的两种方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • JAVA一个快速排序实现代码

    JAVA一个快速排序实现代码

    排序有哪几种方法?请列举。并用JAVA实现一个快速排序.,需要的朋友可以参考下
    2017-02-02
  • 宝塔升级JDK版本超详细图文教程

    宝塔升级JDK版本超详细图文教程

    宝塔自动安装的JDK是一种用于开发和运行Java程序的软件开发工具包,下面这篇文章主要给大家介绍了关于宝塔升级JDK版本的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • SpringBoot项目统一枚举转换实践过程

    SpringBoot项目统一枚举转换实践过程

    文章介绍了在Spring Boot项目中统一枚举转换的实践,通过使用自定义的父枚举接口和AttributeConverter、ConverterFactory、JsonSerializer和JsonDeserializer等工具,实现了枚举与数据库、请求参数、响应参数和消息参数之间的自动转换
    2024-12-12

最新评论