怎么理解Mybatis的事务

对于数据库事务,我们都不陌生,数据库的事务(Transaction)是数据库管理系统执行过程中的一个逻辑单位,也是一个不可分割的工作单位。它包含一个或多个SQL语句,这些语句要么全部执行,要么全部不执行。事务是一个原子操作单元,其对数据的修改要么全都执行,要么全都不执行。那么我们就得来看看这个 Mybatis 是怎么处理事务的了。

ACID特性

原子性(Atomicity):事务是一个原子操作单元,其对数据的修改要么全都执行,要么全都不执行。

一致性(Consistency):事务必须使数据库从一个一致性状态变换到另一个一致性状态。

隔离性(Isolation):事务的执行不受其他事务的干扰,事务执行的中间结果对其他事务是不可见的。

持久性(Durability):一旦事务提交,则其结果就是永久性的,即使系统发生崩溃,事务执行的结果也不能丢失。

我们通过使用事务,可以确保数据的完整性和一致性,特别是在多个用户或系统并发访问和修改数据库时。如果没有事务,那么在这些并发操作中可能会出现数据不一致、数据丢失或数据重复等问题。通过使用事务,可以锁定被修改的数据,直到事务完成并提交,从而确保数据的完整性和一致性。

Mybatis的事务

MyBatis 的事务控制可以从以下几个方面入手:

1.事务管理机制的选择:MyBatis 提供了两种主要的事务管理机制,分别是 JDBC 事务管理机制和 MANAGED 事务管理机制。

  • JDBC 事务管理机制:这种机制利用 java.sql.Connection 对象来完成对事务的提交(commit())、回滚(rollback())、关闭(close())等操作。MyBatis 框架自身会管理事务,采用原生的 JDBC 代码去管理事务,如设置 conn.setAutoCommit(false); 来开启事务,并在业务处理完成后手动提交事务 conn.commit();。
  • MANAGED 事务管理机制:在这种机制下,MyBatis 本身不会去实现事务管理,而是让程序的容器(如 JBOSS、Weblogic)来实现对事务的管理。

2.事务的配置:在 MyBatis 的 XML 配置文件中,可以通过节点定义连接某个数据库的信息,而的 type 属性决定了使用哪种类型的事务管理机制。例如,将的 type 配置为 "JDBC" 会使用 JDBC 事务管理机制。

3.事务工厂的创建:MyBatis 的事务管理依赖于 TransactionFactory 事务工厂的创建。根据的 type 配置和 DataSource 实例,TransactionFactory 会创建一个 Environment 对象,该对象表示一个数据库的连接,并且会被设置到 Configuration 实例中,以供后续使用。

4.业务场景的应用:在实际的业务场景中,如购买操作包含多个执行过程(查询库存、下单、更新库存)或两个患者账户之间的转账操作,需要确保这些操作作为一个整体进行,要么全部成功,要么全部失败并回滚。这时就需要引入事务控制,保证整个操作的有效性。

5.事务的边界管理:合理控制事务的边界也是非常重要的。过宽的事务边界可能导致事务执行时间过长,影响系统性能;而过窄的事务边界则可能导致数据不一致。因此,在设计系统时,需要仔细考虑每个事务的边界。

6.异常处理:在事务执行过程中,如果出现异常,需要根据异常类型和业务需求决定是回滚事务还是进行其他处理。确保在出现异常时能够正确地处理事务,避免数据的不一致和丢失。

如何设置Mybatis的全局事务

在 MyBatis 中,全局事务的设置通常依赖于底层的数据库连接池和事务管理器。MyBatis 本身并不直接提供全局事务管理的功能,而是依赖于 JDBC、Spring 或其他容器提供的事务管理机制。下面是一些常见的方法来设置 MyBatis 的全局事务:

1. 使用 JDBC 进行事务管理

如果你的应用没有使用 Spring 或其他容器,你可以直接使用 JDBC 进行事务管理。在 MyBatis 的配置文件中,你可以将事务管理器设置为 JDBC。

<configuration>  <environments default="development">  <environment id="development">  <transactionManager type="JDBC"/>  <dataSource type="POOLED">  <!-- 数据库连接配置 -->  </dataSource>  </environment>  </environments>  <!-- 其他配置 -->  
</configuration>

在代码中,你需要手动管理事务的开启、提交和回滚。

try (SqlSession session = sqlSessionFactory.openSession()) {  // 开启事务  Connection conn = session.getConnection();  conn.setAutoCommit(false);  // 执行业务逻辑...  // 提交事务  conn.commit();  
} catch (Exception e) {  // 回滚事务  try (Connection conn = session.getConnection()) {  if (!conn.isClosed()) {  conn.rollback();  }  } catch (SQLException ex) {  // 处理异常  }  // 处理异常...  
}

2. 使用 Spring 管理 MyBatis 事务

如果你的应用使用了 Spring 框架,那么可以利用 Spring 的声明式事务管理来管理 MyBatis 的事务。这通常是通过在 Spring 配置文件中配置事务管理器,并在需要事务的方法上使用 @Transactional 注解来实现的。

<beans xmlns="http://www.springframework.org/schema/beans"  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xmlns:tx="http://www.springframework.org/schema/tx"  xsi:schemaLocation="http://www.springframework.org/schema/beans  http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  http://www.springframework.org/schema/tx  http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">  <!-- 配置数据源 -->  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  <!-- 数据源属性配置 -->  </bean>  <!-- 配置 SqlSessionFactory -->  <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  <property name="dataSource" ref="dataSource"/>  <!-- 其他配置 -->  </bean>  <!-- 配置事务管理器 -->  <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  <property name="dataSource" ref="dataSource"/>  </bean>  <!-- 开启注解事务管理 -->  <tx:annotation-driven transaction-manager="transactionManager"/>  <!-- 其他配置 -->  
</beans>

Java 代码中使用 @Transactional

@Service  
public class MyService {  @Autowired  private MyMapper myMapper;  @Transactional  public void myTransactionalMethod() {  // 执行业务逻辑...  myMapper.updateSomeData();  // 如果抛出异常,则事务回滚  }  
}

在上面的例子中,@Transactional 注解告诉 Spring 在执行 myTransactionalMethod 方法时应该开启一个事务。如果方法执行成功,则事务提交;如果方法抛出异常,则事务回滚。

3. 使用其他容器的事务管理

除了 Spring,还有其他一些容器或框架也提供了事务管理的功能,如 Java EE 容器。如果你正在使用这些容器或框架,你可以根据它们的文档来配置和管理 MyBatis 的事务。

  • 确保你的数据库连接池支持事务。大多数现代连接池(如 HikariCP、c3p0、DBCP 等)都支持事务。
  • 在使用 Spring 或其他容器管理事务时,确保你的 MyBatis Mapper 接口或实现类被正确地扫描和注册为 Spring Bean。
  • 在使用 @Transactional 注解时,注意其传播行为(propagation behavior)、隔离级别(isolation level)等属性的设置,以满足你的业务需求。

所以,你对Mybatis的事务了解了么?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/834197.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

简单数据结构——栈和队列1(栈超全)(初始化,销毁,出栈入栈销毁实现,例题运用)

知识特点 类似数据表链表&#xff0c;在逻辑上依次存储&#xff0c;但对比顺序表和链表有所限制&#xff0c;不能随便存储 一定要先掌握顺序表的实现&#xff0c;本人博客有顺序表专栏大家可以自行查看&#xff0c;看懂顺序表专栏之后再来了解栈的实现会更容易懂。 如果还没…

使用DBeaver连接postgreSql提示缺少驱动

重新安装电脑之后用dbeaver链接数据库的时候&#xff0c;链接PG库一直提示缺少驱动&#xff0c;当选择下载驱动的时候又非常非常慢经常失败&#xff0c;尝试了一下更改源然后下载库驱动就非常快了&#xff0c;当然也包括dbeaver的自动更新。 方法&#xff1a;点击菜单栏【窗口…

闲来装个虚拟机Ubuntu24.04和硬盘分区及挂载

简述 最近ubuntu出新版本了&#xff0c;ubuntu24.04&#xff0c; 俗称高贵食蚁兽。5年前进行Android或者linux开发基本是在windows下的虚拟机中进行。目前&#xff0c;虽然物质基础提高了&#xff0c;功能有独立进行编译、代码管理的服务器了。可以通过ssh登录&#xff0c;但是…

Seata之AT 模式的使用

系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站&#xff0c;这篇文章男女通用&#xff0c;看懂了就去分享给你的码吧。 Seata 是一款开源的…

ChIP-seq染色质图谱检测方法的局限性及改善方式

ChIP-seq是最广泛使用的染色质图谱检测方法&#xff0c;但有很大的局限性&#xff0c;具体表现为&#xff1a; 1.高细胞需求量&#xff1b; 2.低吞吐量&#xff1b; 3.技术困难&#xff1b; 4.高成本&#xff0c;深度测序&#xff1b; 5.数据质量差&#xff0c;变量大 CUT&…

使用CNN或resnet,分别在flower5,flower17,flower102数据集上实现花朵识别分类-附源码-免费

前言 使用cnn和resnet实现了对flower5&#xff0c;flower17&#xff0c;flower102数据集上实现花朵识别分类。也就是6份代码&#xff0c;全部在Gitee仓库里&#xff0c;记得点个start支持谢谢。 本文给出flower17在cnn网络实现&#xff0c;flower102在resnet网络实现的代码。…

docker私有仓库的registry

简介 Docker私有仓库的Registry是一个服务&#xff0c;主要用于存储、管理和分发Docker镜像。具体来说&#xff0c;Registry的功能包括&#xff1a; 存储镜像&#xff1a;Registry提供一个集中的地方来存储Docker镜像&#xff0c;包括镜像的层次结构和元数据。 版本控制&…

基于HSI模型的水下图像增强算法,Matlab实现

博主简介&#xff1a; 专注、专一于Matlab图像处理学习、交流&#xff0c;matlab图像代码代做/项目合作可以联系&#xff08;QQ:3249726188&#xff09; 个人主页&#xff1a;Matlab_ImagePro-CSDN博客 原则&#xff1a;代码均由本人编写完成&#xff0c;非中介&#xff0c;提供…

【数据结构】-- 链表专题

链表的分类 前面我们实现了单链表&#xff0c;单链表只是链表的一种。可以根据以下几个标准来判断链表的类型&#xff1a; 1.单向或者双向 如图所示&#xff0c;单向链表中一个节点的指针域只储存了下一个节点的指针&#xff0c;能通过前一个节点访问后一个节点&#xff0c;无…

【4089】基于小程序实现的互动打卡系统

作者主页&#xff1a;Java码库 主营内容&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app等设计与开发。 收藏点赞不迷路 关注作者有好处 文末获取源码 技术选型 【后端】&#xff1a;Java 【框架】&#xff1a;spring…

怎么写毕业论文的? 推荐4个AI工具

写作这件事一直让我们从小学时期就开始头痛&#xff0c;初高中时期800字的作文让我们焦头烂额&#xff0c;一篇作文里用尽了口水话&#xff0c;拼拼凑凑才勉强完成。 大学时期以为可以轻松顺利毕业&#xff0c;结果毕业前的最后一道坎拦住我们的是毕业论文&#xff0c;这玩意不…

短视频矩阵系统源码/saas--总后台端、商户端、代理端、源头开发

短视频矩阵系统源码/saas--总后台端、商户端、代理端、源头开发 搭建短视频矩阵系统源码的交付步骤可以概括为以下几个关键环节&#xff1a; 1. **系统需求分析**&#xff1a;明确系统需要支持的功能&#xff0c;如短视频的上传、存储、播放、分享、评论、点赞等。 2. **技术选…

Python深度学习基于Tensorflow(5)机器学习基础

文章目录 监督学习线性回归逻辑回归决策树支持向量机朴素贝叶斯 集成学习BaggingBoosting 无监督学习主成分分析KMeans聚类 缺失值和分类数据处理处理缺失数据分类数据转化为OneHot编码 葡萄酒数据集示例 机器学习的流程如下所示&#xff1a; 具体又可以分为以下五个步骤&#…

Python开源工具库使用之运动姿势追踪库mediapipe

文章目录 前言一、姿势估计1.1 姿态关键点1.2 旧版 solution API1.3 新版 solution API1.4 俯卧撑计数 二、手部追踪2.1 手部姿态2.2 API 使用2.3 识别手势含义 参考 前言 Mediapipe 是谷歌出品的一种开源框架&#xff0c;旨在为开发者提供一种简单而强大的工具&#xff0c;用…

[C++核心编程-04]----C++类和对象之封装

目录 引言 正文 01-类和对象简介 02-封装简介 03-封装的意义 04-封装案例之设计学生类 05-封装的权限控制 06-struct和class的区别 07-成员属性设置为私有 08-封装案例1-设计立方体 09-封装案例2-判断点和圆的关系 总结 引言 在C中&#xff0c;…

Failed to build flash-attn:ERROR: Could not build wheels for flash-attn

安装 FlashAttention 的时候遇到报错&#xff1a; Failed to build flash-attn ERROR: Could not build wheels for flash-attn, which is required to install pyproject.toml-based projects可能是安装的版本与环境存在冲突吧&#xff0c;我的环境是&#xff1a; python 3.1…

堆的应用2——TOPK问题

TOPK问题 TOP-K问题&#xff1a;即求数据结合中前K个最大的元素或者最小的元素&#xff0c;一般情况下数据量都比较大。 比如&#xff1a;专业前10名、世界500强、富豪榜、游戏中前100的活跃玩家等。 情况1——数据量小 对于Top-K问题&#xff0c;能想到的最简单直接的方式就…

嵌入式C语言高级教程:实现基于STM32的自适应交通信号控制系统

自适应交通信号控制系统能够基于实时交通流数据调整信号灯的时长&#xff0c;提高路口的通行效率。本教程将指导您如何在STM32微控制器上实现一个基本的自适应交通信号控制系统。 一、开发环境准备 硬件要求 微控制器&#xff1a;STM32F103C8&#xff0c;具备足够的处理能力…

Eclipse下载安装教程(包含JDK安装)【保姆级教学】【2023.10月最新版】

目录 文章最后附下载链接 第一步&#xff1a;下载Eclipse&#xff0c;并安装 第二步&#xff1a;下载JDK&#xff0c;并安装 第三步&#xff1a;Java运行环境配置 安装Eclipse必须同时安装JDK &#xff01;&#xff01;&#xff01; 文章最后附下载链接 第一步&#xf…

[法规规划|数据概念]金融行业数据资产和安全管理系列文件解析(3)

“ 金融行业在自身数据治理和资产化建设方面一直走在前列。” 一直以来&#xff0c;金融行业由于其自身需要&#xff0c;都是国内开展信息化建设最早&#xff0c;信息化程度最高的行业。 在当今数据要素资产化的浪潮下&#xff0c;除了行业自身自身数据治理和资产化建设方面&am…