基于 `SqlSession` 的事务手动管理机制

保证数据库操作原子性、维护数据一致性的核心基础

一、概述

MyBatis 自身的事务控制无需依赖外部框架(如 Spring),全程以 SqlSession(SQL 会话对象)为核心载体,所有事务相关操作都围绕该对象展开

其中 commit()(事务手动提交)和 rollback()(事务手动回滚)是该机制的两个核心方法,用于收尾事务流程,确保多步增、删、改操作的原子性(要么全部成功持久化,要么全部失败回滚到原始状态)

MyBatis 默认采用手动事务模式autoCommit=false

二、commit()rollback()

commit() 事务手动提交方法

  • 核心作用 :将当前 SqlSession 事务中,所有已执行但未生效的增、删、改操作,永久同步到数据库中 ,完成事务的正常收尾,事务结束后 SqlSession 会自动开启新的事务

  • 核心特性

    • 依赖默认配置:默认 autoCommit=false,增删改操作执行后仅缓存结果,不会自动生效,必须手动调用此方法才能持久化
    • 缓存联动:无参 commit() 等价于 commit(true),会先刷新 MyBatis 一级、二级缓存,再提交事务,保证缓存与数据库数据一致
    • 原子性保障:同一个 SqlSession 中的多步操作,调用 commit() 会全部生效,不存在 "部分操作持久化" 的情况

rollback() 事务手动回滚方法

  • 核心作用 :当事务执行出现异常(SQL 执行异常、业务逻辑异常等)时,撤销当前 SqlSession 事务中所有未提交的操作,将数据库状态恢复到事务开始前的原始状态,避免数据错乱

  • 核心特性

    • 有效范围限制:仅对 "未调用 commit()" 的未完成事务有效,已提交的事务无法回滚
    • 异常场景专属:通常在 try-catchcatch 块中调用,是保证数据一致性的关键兜底操作
    • 简化使用:日常开发中无参 rollback() 即可满足大部分需求,无需额外配置复杂回滚规则

三、延伸

  1. MyBatis 事务的两种模式

    • 手动事务模式(默认):autoCommit=false,需手动调用 commit()/rollback(),适用于多步操作需保证原子性的场景(如转账:扣款 + 到账需同时成功或失败)
    • 自动事务模式:获取 SqlSession 时指定 openSession(true),开启 autoCommit=true,每一条增删改 SQL 执行后自动提交,仅适用于单步独立操作,无法保证多步操作原子性
  2. SqlSession 关闭的隐含行为

    当调用 sqlSession.close() 释放资源时,若存在未提交的事务,MyBatis 会自动执行 rollback(),撤销所有未持久化的操作,避免残留无效缓存

  3. 事务的适用范围限制

    仅对「增、删、改操作(<insert><update><delete>)」有效,<select> 查询操作不修改数据库数据,不受事务控制,无需提交或回滚

  4. 与 Spring 整合后的变化

    实际项目中,MyBatis 通常与 Spring 整合,事务管理会被 Spring 接管(核心是 @Transactional 注解),无需手动调用 commit()/rollback(),Spring 会根据执行结果自动完成事务收尾

四、核心价值

  1. 保证数据一致性:避免多步操作中 "部分成功、部分失败" 导致的数据错乱,符合业务逻辑完整性要求
  2. 灵活控制事务流程:无需依赖外部框架,即可完成基础事务管理,适配简单项目的开发需求
  3. 为框架整合打基础:理解 MyBatis 原生事务机制,能更好地掌握其与 Spring 事务的整合逻辑,提升复杂项目开发规范性

总结

  1. 核心知识点:MyBatis 基于 SqlSession 的事务手动管理机制
  2. 核心前提:默认 autoCommit=false(手动事务模式)
  3. 核心方法:commit()(持久化操作)、rollback()(撤销未提交操作)
  4. 核心价值:保证数据库操作原子性,维护数据一致性
相关推荐
xuansec2 小时前
【JavaEE安全】JNDI 注入从原理到实战:RMI、LDAP 与高版本绕过
python·安全·java-ee
李慕婉学姐2 小时前
Springboot传统文化服饰交流平台k79z52ic(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
Predestination王瀞潞2 小时前
映射文件中的四大核心 CRUD 操作标签(对应数据库的增、删、改、查操作)
数据库·oracle
IvorySQL2 小时前
PostgreSQL 技术日报 (3 月 12 日)|为什么加索引反而变慢?这招让查询快 50 倍
数据库·postgresql·开源
y = xⁿ2 小时前
【从零开始学习Redis|第五篇】Redis 常见数据类型和应用场景
数据库·redis·学习·缓存
DolphinDB智臾科技3 小时前
DolphinDB:技术赋能钢铁业,国产时序数据库领路数智化落地
数据库·物联网·时序数据库·dolphindb
熬夜有啥好3 小时前
Linux软件编程——数据库——自制小词典
数据库·linux软件编程·自制词典
青桔柠薯片3 小时前
数据库编程:从SQLite基础到C语言集成
linux·数据库·学习·sqlite