基于 `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. 核心价值:保证数据库操作原子性,维护数据一致性
相关推荐
TDengine (老段)9 小时前
TDengine IDMP 工业数据建模 —— 数据标准化
大数据·数据库·物联网·ai·时序数据库·tdengine·涛思数据
羊小蜜.9 小时前
Mysql 01:基础查询(SELECT)全解——从单表到多字段的完整语法
数据库·mysql·查询
猿小喵9 小时前
记录一次从库并行回放出现死锁的问题
数据库·mysql·tdsql
随风,奔跑9 小时前
Redis
数据库·redis·缓存
IvorySQL9 小时前
2MB 的 PostgreSQL work_mem,如何吃掉 2TB 内存?
数据库·postgresql·开源
桑榆肖物9 小时前
有字幕,没配音?用浏览器自带语音能力,让网页视频直接“开口说话”
数据库·edge·音视频·tts
熬夜的咕噜猫10 小时前
MySQL主从复制与读写分离
网络·数据库·mysql
道清茗10 小时前
【MySQL知识点问答题】 备份技术、Invisible Indexes 和直方图的应用
数据库·mysql
芒果披萨10 小时前
sql存储过程
java·开发语言·数据库
jnrjian10 小时前
RAC 去除node的建议 dbca 和手动方法
数据库·oracle