日常问题:解决nested exception is org.apache.ibatis.executor.ExecutorException: No constructor found问题

问题描述:
在调试上周编写好的代码程序时,执行到 MyBatis 获取某行数据并转换成自定义类型时,突然抛出了异常:

nested exception is org.apache.ibatis.executor.ExecutorException: No constructor found

我顿时就感到困惑,因为自定义类中的字段和类型与数据结构完全一致。然而,在异常提示中出现了 constructor 这个关键字,让我想到可能是与自定义类型中定义了有参构造函数有关。当从数据库获取某行数据时,由于缺少无参构造函数,导致异常出现。

解决方法:
针对这个问题,我们可以简单地添加一个无参构造函数即可,这个无参构造函数不一定要包含所有的字段。在这里,可以理解为使用 MyBatis 查询一个实例时,抽象实体类必须有一个无参构造方法。

注:
默认情况下,每个实体类都有一个无参构造函数。但如果我们自己添加了有参构造函数,那么默认的无参构造函数就会失效,需要手动添加无参构造函数。

在修改后的实体类中添加无参构造函数的示例代码如下:

public class CustomEntity {
    private Long id;
    private String name;

    // 有参构造函数
    public CustomEntity(Long id, String name) {
        this.id = id;
        this.name = name;
    }

    // 无参构造函数
    public CustomEntity() {
        // 这里可以为空,或者进行一些默认初始化操作
    }

    // 省略 getter 和 setter 方法
}

通过添加这样一个简单的无参构造函数,我们就能够解决 MyBatis 抛出 No Constructor Found 异常的问题,确保在从数据库中获取数据并转换成自定义类型时能够顺利执行。

19:11:38.498 [http-nio-8080-exec-3] ERROR o.a.c.c.C.[.[.[.[dispatcherServlet] - [log,175] - Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.executor.ExecutorException: No constructor found in void matching [java.lang.Long, java.lang.Long, java.lang.Long, java.lang.String, java.math.BigDecimal, java.lang.Integer]] with root cause org.apache.ibatis.executor.ExecutorException: No constructor found in void matching [java.lang.Long, java.lang.Long, java.lang.Long, java.lang.String, java.math.BigDecimal, java.lang.Integer] at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.createByConstructorSignature(DefaultResultSetHandler.java:702) at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.createResultObject(DefaultResultSetHandler.java:658) at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.createResultObject(DefaultResultSetHandler.java:631) at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.getRowValue(DefaultResultSetHandler.java:398) at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.handleRowValuesForSimpleResultMap(DefaultResultSetHandler.java:355) at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.handleRowValues(DefaultResultSetHandler.java:329) at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.handleResultSet(DefaultResultSetHandler.java:302) at org.apache.ibatis.executor.resultset.DefaultResultSetHandler.handleResultSets(DefaultResultSetHandler.java:195) at org.apache.ibatis.executor.statement.PreparedStatementHandler.query(PreparedStatementHandler.java:65) at org.apache.ibatis.executor.statement.RoutingStatementHandler.query(RoutingStatementHandler.java:79) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl
05-23
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hugo_Hoo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值