news 2026/6/9 22:22:01

MyBatis-Plus 报错 Invalid bound statement(insert)?其实是 SqlSessionFactoryBean 踩坑了

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MyBatis-Plus 报错 Invalid bound statement(insert)?其实是 SqlSessionFactoryBean 踩坑了

在 Spring Boot 项目中接入MyBatis-Plus时,很多人都会遇到下面这个异常:

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): cn.xxx.xxxmapper.HaMapper.insert

表面看起来像是Mapper 或 XML 没配置好,但如果你已经:

  • Mapper 能正常注入

  • XML 的select能用

  • 唯独BaseMapper.insert()报错

👉 那99% 是 SqlSessionFactoryBean 配置导致的

本文通过一次真实踩坑经历,系统讲清楚:

  • 问题产生的根因

  • 为什么 MyBatis-Plus 特别容易中招

  • 正确 & 官方推荐的解决方案


一、问题现象

异常信息如下:

Invalid bound statement (not found): cn.ha.xx.xxmapper.HaMapper.insert

对应代码:

haMapper.insert(entity);

HaMapper定义如下:

public interface HaMapper extends BaseMapper<HaEntity> { }

看起来完全没问题,但一运行就报错。


二、为什么 MyBatis-Plus 会在 insert 上报错?

1️⃣ BaseMapper 的 SQL 是「自动注入」的

这是关键背景。

  • insert / deleteById / updateById

  • 并不在 XML 中

  • 而是在SqlSessionFactory 初始化时

  • 由 MyBatis-Plus 动态注册

这个注册过程只会发生在:MybatisSqlSessionFactoryBean中。

2️⃣ 手动配置 SqlSessionFactoryBean 会发生什么?

很多项目(尤其是老项目 / 多数据源)都会写类似配置:

@Bean public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception { SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean(); factoryBean.setDataSource(dataSource); return factoryBean.getObject(); }

⚠️问题就在这里

你虽然成功创建了 SqlSessionFactory,但:

  • ❌ 绕开了 MyBatis-Plus 的自动配置

  • ❌ BaseMapper 的 CRUD SQL 根本没有被注入

结果就是:

XML 里的 SQL 能用 BaseMapper.insert → Invalid bound statement


三、如何快速判断是不是这个坑?

你可以对照下面这个表:

现象是否命中该问题
Mapper 能注入
XML select 正常
BaseMapper.insert 报错
项目中存在 SqlSessionFactoryBean100% 命中

如果你手动 new 了 SqlSessionFactoryBean,几乎可以直接确认原因。


四、正确的解决方案(官方推荐)

✅ 方案一:删除自定义 SqlSessionFactory(最推荐)

如果你不是多数据源、也没有特别定制需求:

@Configuration @MapperScan("cn.ha.xx.xxmapper") public class MybatisPlusConfig { }

只保留依赖:

<dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> </dependency>

👉 MyBatis-Plus 会自动:

  • 使用MybatisSqlSessionFactoryBean

  • 注入 BaseMapper CRUD

  • 扫描 Mapper

这是最稳妥、最不容易出问题的方式。


✅ 方案二:必须自定义时,用 MybatisSqlSessionFactoryBean

如果你确实需要手动配置(如插件、多数据源):

@Bean public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception { MybatisSqlSessionFactoryBean factory = new MybatisSqlSessionFactoryBean(); factory.setDataSource(dataSource); factory.setMapperLocations( new PathMatchingResourcePatternResolver() .getResources("classpath:/mapper/**/*.xml") ); return factory.getObject(); }

重点只有一句

不要再使用SqlSessionFactoryBean


✅ 方案三:多数据源场景(高频踩坑)

@Bean @Primary public SqlSessionFactory primarySqlSessionFactory(DataSource dataSource) throws Exception { MybatisSqlSessionFactoryBean factory = new MybatisSqlSessionFactoryBean(); factory.setDataSource(dataSource); return factory.getObject(); }

配合:

@MapperScan( basePackages = "cn.ha.xx.xxmapper", sqlSessionFactoryRef = "primarySqlSessionFactory" )

五、为什么这个坑特别隐蔽?

原因只有一个:

它不是配置错误,而是“配置覆盖成功了,但逻辑被绕开了”

  • 不报 Bean 冲突

  • 不报启动异常

  • 直到你调用BaseMapper.insert才炸

非常具有迷惑性。

六、总结

如果你在 MyBatis-Plus 中遇到:

Invalid bound statement (not found): xxxMapper.insert

请第一时间检查:

❗ 是否手动配置了 SqlSessionFactoryBean

记住一句话就够了:

👉 用 MyBatis-Plus,就要让它掌控 SqlSessionFactory

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 8:25:13

智能时代测试新范式:专家解读AI驱动与DevOps融合

测试专家的价值与时代意义 在数字化浪潮席卷全球的今天&#xff0c;软件质量已成为企业竞争力的核心要素。作为软件测试从业者&#xff0c;我们不仅是缺陷的发现者&#xff0c;更是质量文化的推动者。测试专家通过多年的项目历练&#xff0c;总结出宝贵的经验教训&#xff0c;…

作者头像 李华
网站建设 2026/6/10 11:47:48

Web Components 核心技术:Shadow DOM 的样式隔离与 Slot 插槽机制

Web Components 核心技术&#xff1a;Shadow DOM 的样式隔离与 Slot 插槽机制&#xff08;讲座版&#xff09;各位同学、开发者朋友们&#xff0c;大家好&#xff01;今天我们来深入探讨一个在现代前端开发中越来越重要的概念——Web Components。特别是其中的两个核心技术&…

作者头像 李华
网站建设 2026/6/10 1:36:38

Spring Boot3 集成 UUIDv7 有序、高性能 ID 生成方案

1、简述在分布式系统中&#xff0c;ID 生成是一个非常关键的基础能力。传统的 UUID&#xff08;如 v4&#xff09;虽然随机性强&#xff0c;但存在&#xff1a;无序&#xff0c;不利于数据库索引无法按时间排序长度大&#xff0c;不适合高写入场景为了解决这些问题&#xff0c;…

作者头像 李华
网站建设 2026/6/10 15:57:37

Sensitive 框架日志脱敏

在企业级 Java 开发中&#xff0c;日志往往是最重要的“真相记录者”——它精准地还原了系统运行的全过程。然而&#xff0c;日志也可能成为“信息泄露的温床”&#xff1a;用户身份证号、手机号、银行卡号、甚至密码&#xff0c;可能在日志中赤裸裸地暴露出来。 这不仅违反合规…

作者头像 李华
网站建设 2026/6/9 19:55:25

ArcGIS大师之路500技---033水文分析

文章目录前言一、 DEM镶嵌二、 裁剪三、填洼四、 计算流向五、 计算汇流累积量六、栅格河网提取七、矢量化河网八、河流连接九、绘制倾泄点十、捕捉倾泻点十一、生成流域十二、流域转面十三、流域面裁切DEM总结前言 水文分析全过程&#xff1a;数据集准备&#xff08;镶嵌、裁…

作者头像 李华
网站建设 2026/6/10 15:57:51

年薪50w的财务总监是这样写成本分析报告的

目录 一、写报告到底要解决什么问题&#xff1f; 二、数据收集 1.直接成本数据 2.间接成本数据 3.业务关联数据 三、核心分析维度 1.变动成本vs固定成本分析 2.单产品成本拆解 3.部门/环节成本分析 4.成本差异分析 5.盈亏分析法 四、避坑指南 1.数据口径不一致 2…

作者头像 李华