当前位置: 首页 > 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.rkmt.cn/news/117485.html

相关文章:

  • Qt实现Ubuntu程序自动重启
  • 2025年12月食堂净化水处理设备,除铁锰水处理设备,反渗透水处理设备厂家榜:适配性与能耗双维度测评 - 品牌鉴赏师
  • 必看!方形与圆形油炸机挑选,这几个关键要点你得知道
  • 机器学习--逻辑回归
  • 29、Unix 文件操作与管理全解析
  • 第1节:项目性能优化(上)
  • 解析现代网络的“神经系统”—BGP-LS-SPF
  • win11使用KMS命令激活
  • 12月17日
  • 从零构建高性能KV存储服务器:架构设计与实现细节 - 指南
  • 项目实战05—XXX火力发电厂工业蒸汽量预测
  • iOS 应用发布流程中常被忽视的关键环节
  • AI agent 最新 进展
  • WSL2安装教程
  • 人才盘点驱动组织发展
  • PPT排版又丑又慢怎么办?这个“AI生成PPT”功能,3秒拯救你的PPT
  • 邻项交换贪心小记
  • 2025年12月对焊机厂家推荐:行业权威盘点与焊接设备品质红榜发布 - 品牌鉴赏师
  • 人才发展ℓℓ 人才盘点怎么做?这篇完全应用手册给出答案
  • 12月最新论文降AI率全流程,附免费降AI方法+降AI率工具
  • javascript: Convert Word documents (.docx files) to HTML
  • FPGA中的 LUT6
  • 基于SpringBoot+Vue的宠物代遛系统设计与实现
  • 【即插即用模块】AAAI2025 | 高频 + 空间感知!新 HS-FPN 让“极小目标”不再消失!SCI保二区争一区!彻底疯狂!!!
  • 【24h服务】微信公众号评论点赞好友能看到吗?微信留言点赞下单怎么取消? - 速递信息
  • 一个销售数据分析机器人的诞生:看 Dify 如何在 DMS 助力下实现自动化闭环
  • 模具管理系统新解:如何用数字化打通全生命周期,降本30%?
  • Agentic AI提示工程的商业价值:如何应对AI技术的快速迭代?
  • SAP CDS 带参数传输的视图
  • Android-packages/modules-由来及子目录介绍