当前位置: 首页 > news >正文

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

http://www.jsqmd.com/news/106448/

相关文章:

  • 【2025最新】Sumatra PDF 下载安装教程:轻量高效的PDF阅读器全方位指南
  • 小白也能跑通华为云OCR:手把手整合 Hutool 与华为云签名 SDK 并解决依赖难题
  • Qt/C++实现Ubuntu应用自重启
  • C++可变参数队列与压栈顺序:从模板语法到汇编调用约定的深度解析
  • 2025年12月HT250灰铁,HT200灰铁,灰铁棒料厂商推荐:聚焦铸造企业综合实力与核心竞争力 - 品牌鉴赏师
  • 【从 “堵车” 到 “飙车”:Java 并发 / 并行终极解析 + 接口抗并发实战指南】
  • Qt实现Ubuntu程序自动重启
  • 制砂机远程监控运维管理系统方案
  • 2025年12月水处理设备用阻垢剂,水处理设备用活性炭,地下水处理设备公司推荐:资质核验+案例解析 - 品牌鉴赏师
  • 灌区PLC阀门远程监控运维系统方案
  • 2025年12月食堂净化水处理设备,除铁锰水处理设备,反渗透水处理设备厂家榜:适配性与能耗双维度测评 - 品牌鉴赏师
  • 机器学习--逻辑回归
  • 29、Unix 文件操作与管理全解析
  • 第1节:项目性能优化(上)
  • 什么是云桌面?一般都用哪些云桌面?
  • 解析现代网络的“神经系统”—BGP-LS-SPF
  • Linux-LVM 方式挂载大于3T磁盘,详细操作过程
  • 30、深入理解 inotify 与内存管理
  • 【昇腾CANN训练营·核心篇】拒绝“写死”:Ascend C 算子动态 Tiling 的设计哲学
  • win11使用KMS命令激活
  • 学习日记day50
  • 【LangChain4J】图生文文生图,以及第三方平台集成
  • 用频繁跳槽换来的技术积累,对于实际的开发人员来说不是什么好事。 - ukyo-
  • 12月17日
  • “管理员阻止你运行此应用”怎么办?详解系统权限解除与一键修复方案
  • 第11讲 蓝牙模块与建议数据包解析
  • AI agent 最新 进展
  • 商品颜色/尺码选项太多|谷歌爬虫不收录怎么办
  • 交换机基础拥塞处理机制(Tail Drop 、RED、ECN)
  • 2025年12月球墨铸铁,QT400-18球墨铸铁,球墨铸铁棒料公司推荐:行业测评与选择指南 - 品牌鉴赏师