文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-09-05 16:41

关注

错误提示:

服务器处理发生异常: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

来源地址:https://blog.csdn.net/qq_45656077/article/details/129178272

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯