0

0

Spring事务管理的相关介绍(附代码)

不言

不言

发布时间:2018-10-09 14:34:33

|

2914人浏览过

|

来源于博客园

转载

本篇文章给大家带来的内容是关于spring事务管理的相关介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

事务

逻辑上的一组操作,组成操作的每个部分要么全部成功,要么全部失败

事务的特性

  • 一致性: 事务前后数据完整性保持一致

  • 原子性: 事务不能够分割,要么全部成功,要么全部失败

  • 隔离性: 事务的执行不受到其他事务的影响,相互之间隔离

  • 持久性: 事务一旦完成,那么就会保存到数据库中,不受系统崩溃的影响

如果不满足特性引发的问题

隔离性引发的问题:

读问题

  • 脏读:事务读到其他事务还没有commit的数据

  • 不可重复读: 一个事务读取到其他事务提交的更新update数据,导致多次的查询结果不一致

  • 幻读: 一个事务读到其他事务插入insert的数据,导致多次查询结果不一致

写问题

  • 丢失操作

解决读问题

设置事务的隔离级别

Spring事务管理的相关介绍(附代码)

   int ISOLATION_DEFAULT = -1;
    int ISOLATION_READ_UNCOMMITTED = 1;
    int ISOLATION_READ_COMMITTED = 2;
    int ISOLATION_REPEATABLE_READ = 4;
    int ISOLATION_SERIALIZABLE = 8;
  • ISOLATION_DEFAULT: 代表spring默认值,表示使用底层数据库的默认隔离级别。比如mysql 使用ISOLATION_REPEATABLE_READ使用ISOLATION_READ_COMMITTED

  • ISOLATION_READ_UNCOMMITTED: 未提交读,不可以解决读问题

  • ISOLATION_READ_COMMITTED: 已提交读,可以解决脏读,不能解决幻读和不可重复读

  • ISOLATION_REPEATABLE_READ: 重复读,可以解决脏读和不可重复读

  • ISOLATION_SERIALIZABLE: 可以解决所有读问题,效率不高

Spring中事务管理的api

PlatformTransactionManager:平台事务管理器
PlatformTransactionManager是一个接口,是Spring底层用来管理事务的对象。
平台事务管理器.png

public interface PlatformTransactionManager {
    TransactionStatus getTransaction(TransactionDefinition definition) throws TransactionException;
    void commit(TransactionStatus status) throws TransactionException;
    void rollback(TransactionStatus status) throws TransactionException;
}

spring事物官网地址
比较常见的实现类有:

  1. DataSourceTransactionManager:底层使用JDBC事务管理

  2. HibernateTransactionManager:底层使用Hibernate事务管理

    asp.net企业网站管理系统1.0
    asp.net企业网站管理系统1.0

    后台地址/manage,后台帐号admin密码为 admin公司企业网站管理系统超漂亮,由深圳http://www.sunsuc.com公司企业网站建设专家自主开发,是一套通用的,公司,企业自助建站网站管理系统,美观的前台,强大的网站后台管理功能,自助管理前台相关栏目.使公司,企业网站,最大范围被人了解,占得网络市场.本系统有宣传,介绍,展示,推广,销售公司企业的产品与服务,开展网上电子商务业务的

    下载
  • TransactionDefinition:
    事务定义:可以定义事务的相关信息,事务传播行为,隔离级别,超时信息,是否只读

package org.springframework.transaction;

//可以看到事物的定义也是一个接口
public interface TransactionDefinition {
    //事物的传播行为,7种
    int PROPAGATION_REQUIRED = 0;
    int PROPAGATION_SUPPORTS = 1;
    int PROPAGATION_MANDATORY = 2;
    int PROPAGATION_REQUIRES_NEW = 3;
    int PROPAGATION_NOT_SUPPORTED = 4;
    int PROPAGATION_NEVER = 5;
    int PROPAGATION_NESTED = 6;
    
    //事物的隔离级别五种
    int ISOLATION_DEFAULT = -1;
    int ISOLATION_READ_UNCOMMITTED = 1;
    int ISOLATION_READ_COMMITTED = 2;
    int ISOLATION_REPEATABLE_READ = 4;
    int ISOLATION_SERIALIZABLE = 8;

    //事物的超时时间,-1代表没有超时时间
    int TIMEOUT_DEFAULT = -1;

    int getPropagationBehavior();

    int getIsolationLevel();

    int getTimeout();

    boolean isReadOnly();

    String getName();
}
  • TransactionStatus: 事务状态
    事务状态: 记录管理事务过程中事务状态的对象

Spring中七种事务的传播行为

事务的传播行为是用来解决业务方法之间相互调用的问题

官网传送门

前置条件:
方法B()中调用方法A()

嵌套事务

  • PROPAGATION_NESTED: A中有事务,A事务正常执行。A事务执行完成后,设置一个保存点,执行B操作,如果B抛出异常则可回滚到初始位置或者回滚到保存点

保证操作在同一个事务里

  • PROPAGATION_REQUIRED: 如果B方法调用A方法,A方法有事务,B方法就会使用A中的事务。如果A中没有,B就会创建一个事务

  • PROPAGATION_SUPPORTS: B调用A,A中有事务,使用A中的事务,A中没有事务则B不使用事务

  • PROPAGATION_MANDATORY: 如果A用有事务,使用A中的事务,A中没有事务,抛出异常

保证操作不在同一个事务里

  • PROPAGATION_REQUIRES_NEW : A中有事务,把A事务挂起,B开启事务只包含自身操作。A中没有,B创建事务只包含自身操作

  • PROPAGATION_NOT_SUPPORTED: A中有事务,A挂起,B不使用事务
    *PROPAGATION_NEVER: A中有事务B抛出异常

Spring提供了而两种事务管理方式

  • 声明式事务管理: 在Spring配置文件中声明式的处理事务来代替代码式的处理事务(使用的比较多)

  • 编程事务管理:代码式的处理事务,需要在程序中编写代码

    声明式事务管理

    基于xml


    
        
    

    
        
            
            
            
            
            
            
        
    
    
    
        
        
    

save*表示方法以save开头的方法,使用PROPATATION_REQUIRED事务传播,使用REPEATABLE_READ事务隔离

基于注解


    
        
    
    
    

使用tx:annotation-driven 开启事务的注解后,在使用的时候只需要在类或者方法上加入@Transactional就可以开启注解

基于xml的事务和基于注解的事务对比

  • 文件配置对比
    事务基于注解简化了xml中的

  • 使用比较
    使用注解必须在类或者方法上添加@Trasactional,如果有多个业务类,则需要在每个业务类上添加
    使用xml只需要在配置文件中配置包名即可

事务github代码

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

653

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

244

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

280

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

513

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

250

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

384

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

523

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

594

2023.08.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Spring中文手册
Spring中文手册

共0课时 | 0人学习

马士兵spring视频教程
马士兵spring视频教程

共25课时 | 9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号