news 2026/4/15 12:03:32

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/4/12 20:30:59

制砂机远程监控运维管理系统方案

制砂机作为矿山、建筑及道路工程中破碎与制砂作业的核心设备&#xff0c;其运行效率与稳定性直接关系到工程进度与产品质量。制砂机在工作过程中&#xff0c;涉及电机转速、进料量、出料粒度、振动强度及轴承温度等多个关键参数的实时监控与调节。 但传统运维方式依赖现场巡检与…

作者头像 李华
网站建设 2026/4/12 10:42:53

数字化航空的安全基石:测试人员如何应对DO-178C与网络安全双重要求

航空软件安全认证的重要性 航空软件安全认证是确保航空系统&#xff08;如飞行控制、导航和通信系统&#xff09;在极端环境下可靠运行的关键流程。对于软件测试从业者而言&#xff0c;理解认证标准&#xff08;如DO-178C&#xff09;不仅是合规要求&#xff0c;更是保障乘客安…

作者头像 李华
网站建设 2026/4/14 9:37:15

利用 `Object.defineProperty` 实现 Vue2 风格的数组变异方法监听

利用 Object.defineProperty 实现 Vue2 风格的数组变异方法监听 各位同学&#xff0c;大家好&#xff01;今天我们来深入探讨一个在前端开发中非常经典且重要的问题&#xff1a;如何实现类似 Vue 2 中对数组变化的响应式监听机制。这不仅是理解 Vue 响应式原理的核心环节&…

作者头像 李华
网站建设 2026/4/8 22:23:30

Redux 中间件原理:洋葱模型(Onion Model)的 `compose` 函数手写实现

Redux 中间件原理详解&#xff1a;洋葱模型与 compose 函数的手写实现各位开发者朋友&#xff0c;大家好&#xff01;今天我们来深入探讨一个在 Redux 生态中非常重要但又常被忽视的概念——中间件的执行机制&#xff0c;尤其是其中的核心设计思想&#xff1a;洋葱模型&#xf…

作者头像 李华