基于 `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. 核心价值:保证数据库操作原子性,维护数据一致性
相关推荐
weelinking4 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
稳联技术老娜5 小时前
DeviceNet主站怎么连接西门子PLC,Profinet网关配置手册(那智机器人)
服务器·网络·数据库
这个DBA有点耶5 小时前
云上运维新挑战:当数据库不再“看得见摸得着”
数据库·sql·程序人生·云原生·运维开发·学习方法·dba
AskHarries6 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
消失在人海中6 小时前
oracle 数据库多表关联查询
服务器·数据库·oracle
九皇叔叔6 小时前
PostgreSQL/openGauss pg_stats 视图从入门到精通:统计信息、执行计划与慢 SQL 优化实战
数据库·sql·postgresql
南极企鹅7 小时前
MySQL间隙锁&临键锁
数据库·sql·mysql
TDengine (老段)8 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
苏渡苇9 小时前
Redis 持久化——RDB 快照 vs AOF 日志
数据库·redis·缓存·redis持久化·aof vs rdb
l1t10 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器
数据库·sql