2025年3月26日 星期三 甲辰(龙)年 月廿五 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > MyBatis

Mybatis异常分析之 org.apache.ibatis.executor.result.ResultMapException

时间:03-12来源:作者:点击数:8

前文

本文章主要正对org.apache.ibatis.executor.result.ResultMapException

异常出现情况分析。从原理角度明白为啥会有这样的异常,以后不管那种场景下,明白原理后,不需要百度自己即可知道问题的根源。

怎么会出现这样错误

情况一

一种是自己数据字段类型和实体类型没有对应的映射的,比如数据库是user_id 是bigint实体是user_id 是Date

情况二

字段都对的,就是使用了lombok.Builder @Builder 这个会给我们自动生成构造方法

通过源码分析原理

情况一分析

根据实体类型获取对应的Handler 处理数据库查出的值,发现转换的时候不合法。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
情况二分析
在这里插入图片描述
在这里插入图片描述

这个是由于咱们代码实体顺序和数据库不一致,导致@Builder 生成的构造方法是按照实体来得当遍历比对的时候就发现类型不一致的,根本原因还是情况一。

如何解决

情况一解决

对象类型值与mysql 一一对应

在这里插入图片描述
情况二解决
  1. 剔除注解@Builder 或者@AllArgsConstructor 代理生成构造方法注解都要剔除。
  2. 第一条不剔除的话,按照数据库查询出来顺序来构造类的构造方法。
  3. 还有一种情况就是返回的实体是组合实体,比如多表联查的实体Vo 或者DTO,一定慎用@Builder.
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
上一篇:Chapter 1 MyBatis 入门 下一篇:很抱歉没有了
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐