Spring学习JdbcTemplate数据库事务参数

目录
  • Spring JdbcTemplate数据库事务参数
    • 一、propagation
      • 1. REQUIRED
      • 2. REQUIRES_NEW
      • 3. SUPPORTS
      • 4. NOT_SUPPORTED
      • 5. MANDATORY
      • 6. NEVER
      • 7. NESTED
    • 二、ioslation
    • 三、timeout
    • 四、readOnly
    • 五、rollbackFor
    • 六、noRollbackFor

Spring JdbcTemplate数据库事务参数

@Transactional() 注解里有不少参数,其中我们常用到的如下:

一、propagation

表示事务传播行为。就是说多个事务方法之间进行调用,这个过程中事务是如何进行管理的。

这里的事务方法就是指对数据库表数据进行变化操作的方法。

举例:

有个 update() 方法:

public void update() {
}

还有个 add() 方法:

public void add() {
  // 调用了update()方法
  update()
}

那么,现在当其中一个方法加上了事务注解 @Transactional 后,调用执行过程是怎样的?或者说两个都加了事务注解,又该如何?

为了解决问题,spring 事务传播行为有 7 种:

REQUIRED:默认参数。如果有事务在运行,当前方法就在这个事务内运行,否则就开启一个新的事务,并在自己的事务内运行。

REQUIRES_NEW:当前的方法必须在启动新事务,并在它自己的事务内运行,如果有事务在进行,应该将它挂起。

SUPPORTS:如果有事务在运行,当前的方法就在这个事务内运行,否则它可以不运行在事务中。

NOT_SUPPORTED:当前的方法不应该运行在事务中,如果有运行的事务,将它挂起。

MANDATORY:当前的方法必须运行在事务内部,如果没有正在运行的事务,就抛出异常。

NEVER:当前的方法不应该在事务中运行,如果有运行的事务,就抛出异常。

NESTED:如果有事务在运行,当前的方法就应该在这个事务的嵌套事务内运行,否则,就启动一个新的事务,并在自己的事务内运行。

1. REQUIRED

如果有事务在运行,当前方法就在这个事务内运行,否则就开启一个新的事务,并在自己的事务内运行。

@Transactional(propagation = Propagation.REQUIRED)
public void methodA() {
  methodB();
  // do something
}
@Transactional(propagation = Propagation.REQUIRED)
public void methodB() {
  // do something
}

当调用 methodA 时,因为当前上下文不存在事务,所以会开启一个新的事务。当执行到 methodB 时,发现当前上下文存在事务,因此就加入到当前事务来执行。当单独调用 methodB 时,因为当前上下文不存在事务,所以会开启一个新的事务。

2. REQUIRES_NEW

当前的方法必须在启动新事务,并在它自己的事务内运行,如果有事务在进行,应该将它挂起。

@Transactional(propagation = Propagation.REQUIRED)
public void methodA() {
doSomeThingA();
methodB();
doSomeThingB();
// do something else
}
// 事务属性为REQUIRES_NEW
@Transactional(propagation = Propagation.REQUIRES_NEW)
public void methodB() {
    // do something
}

当调用 methodA 时,开启了 事务 A。执行到 methodB 时,开启一个事务B,此时事务 A 挂起,当事务 B 执行完成后,继续执行事务 A 。

  • 这里的事务 A 称为外层事务。
  • 这里的事务 B 则称为内层事务。

3. SUPPORTS

如果有事务在运行,当前的方法就在这个事务内运行,否则它可以不运行在事务中。

@Transactional(propagation = Propagation.REQUIRED)
public void methodA() {
 methodB();
// do something
}
// 事务属性为SUPPORTS
@Transactional(propagation = Propagation.SUPPORTS)
public void methodB() {
    // do something
}

当调用 methodA 时,methodB 加入到 methodA 的事务中,事务的执行。当单独的调用 methodB 时,methodB方法是非事务的执行的。

4. NOT_SUPPORTED

当前的方法不应该运行在事务中,如果有运行的事务,将它挂起。

  • 当调用 methodA 时,开启 事务 A。当执行到 methodB 时,挂起事务A,以非事务的方式执行 methodB 。
  • 当单独的调用 methodB 时,methodB方法是非事务的执行的。

5. MANDATORY

当前的方法必须运行在事务内部,如果没有正在运行的事务,就抛出异常。

@Transactional(propagation = Propagation.REQUIRED)
public void methodA() {
 methodB();
// do something
}
// 事务属性为MANDATORY
@Transactional(propagation = Propagation.MANDATORY)
public void methodB() {
    // do something
}

当调用 methodA 时,methodB 则加入到 methodA 的事务中,事务地执行。当单独调用 methodB 时,因为当前没有一个活动的事务,则会抛出异常。

6. NEVER

当前的方法不应该在事务中运行,如果有运行的事务,就抛出异常。

7. NESTED

如果有事务在运行,当前的方法就应该在这个事务的嵌套事务内运行,否则,就启动一个新的事务,并在自己的事务内运行。

  • 当单独执行 methodB ,开启事务 B,执行。
  • 当执行 methodA 时,开启事务 A,执行到 methodB,开启内层事务 B。

注意 当执行 methodA 时,这里是一个嵌套事务。

如果外层事务失败,则会回滚内层事务所做的操作。但是内层事务的失败不会引起外层事务的回滚。

二、ioslation

设置事务隔离级别。

因为不同的事务隔离级别会引起不同的问题,比如:脏读、不可重复读、幻读。

相关的内容在之前有过介绍,有兴趣的可以自行跳转过去:

【Mysql】数据库事务,脏读、幻读、不可重复读

所以要解决,需要设置对应的隔离级别:

  • READ_UNCOMMITTED: 读未提交
  • READ_COMMITTED: 读已提交
  • REPEATABLE_READ: 可重复读
  • SERIALIZABLE: 串行化

三、timeout

设置超时时间。

事务需要在一定时间内进行提交,如果没提交,就回滚。

默认值是 -1 ,表示不超时。如果设置时间,单位是秒(s)。

四、readOnly

设置是否只读。

默认值 false,表示可以查询,也可以进行添加、修改、删除操作。

当设置为 true,只可以进行查询操作。

五、rollbackFor

设置出现哪些异常后就进行事务的回滚。

六、noRollbackFor

设置出现哪些异常后,不进行事务的回滚。

以上就是Spring学习JdbcTemplate数据库事务参数的详细内容,更多关于Spring JdbcTemplate数据库事务的资料请关注我们其它相关文章!

(0)

相关推荐

  • Spring框架+jdbcTemplate实现增删改查功能

    SpringMVC架构(Model(实体类),Service,Controller层) Controller(接收参数调用业务层)–>Service(调用持久层,处理业务逻辑)–>Dao(与数据库交互) 1. IOC(控制反转是一种设计思想而不是技术) DI(依赖注入):是IOC思想的一种技术实现 IOC容器是Spring提供的保存Bean对象的容器 Bean管理操作 1.Xml + 注解 2.javaConfig + 注解 通过xml配置Bean:TODO: 通过javaConfig 配置B

  • 详解SpringBoot中JdbcTemplate的事务控制

    目录 前言 原生Jdbc的事务控制 Spring的声明式事务控制 尝试JdbcTemplate的事务控制 TransactionTemplate的编程式事务控制 前言 JdbcTemplate是spring-jdbc提供的数据库核心操作类,那对JdbcTemplate进行事务控制呢? 我的环境:spring-boot-2.1.3,druid-1.1.3. 原生Jdbc的事务控制 即,批处理+自动提交的控制方式, public static void demo(String[] args) thr

  • 超细致讲解Spring框架 JdbcTemplate的使用

    目录 JdbcTemplate基本使用 1-JdbcTemplate基本使用-概述(了解) 2-JdbcTemplate基本使用-开发步骤(理解) 3-JdbcTemplate基本使用-快速入门代码实现(应用) 4-JdbcTemplate基本使用-spring产生模板对象分析(理解) 5-JdbcTemplate基本使用-spring产生模板对象代码实现(应用) 6-JdbcTemplate基本使用-spring产生模板对象代码实现 7-JdbcTemplate基本使用-常用操作-更新操作(应

  • SpringBoot使用JdbcTemplate访问操作数据库基本用法

    目录 一.建一个rumenz_springboot库 二.加入pom的依赖 三.SpringBoot配置文件 四.创建User实体类 五.Service接口 六.Service接口实现类 七.Controller测试 八.总结 Spring对数据库的操作在jdbc上s面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中. JdbcTemplate在Spring-jdbc包下面,还需要Spring-tx包支持,里面包含事务和异常控制. 一.建

  • Spring框架JdbcTemplate数据库事务管理完全注解方式

    目录 Spring JdbcTemplate事务注解 配置类方式配置 完全注解方式 一.创建配置类 二.测试注解方式的事务管理 Spring JdbcTemplate事务注解 配置类方式配置 在之前的操作中,相关的配置还是写在了 xml 配置文件中.现在,使用配置类的方式进行配置. <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework

  • Java Spring JdbcTemplate基本使用详解

    目录 JdbcTemplate概述 JdbcTemplate开发步骤 JdbcTemplate快速入门 Spring产生JdbcTemplate对象 JdbcTemplate概述 它是spring框架中提供的一个对象,是对原始繁琐的Jdbc API对象的简单封装.spring框架为我们提供了很多的操作模板类.例如:操作关系型数据的JdbcTemplate和HibernateTemplate,操作nosql数据库的RedisTemplate,操作消息队列的JmsTemplate等等. JdbcTe

  • Spring学习JdbcTemplate数据库事务参数

    目录 Spring JdbcTemplate数据库事务参数 一.propagation 1. REQUIRED 2. REQUIRES_NEW 3. SUPPORTS 4. NOT_SUPPORTED 5. MANDATORY 6. NEVER 7. NESTED 二.ioslation 三.timeout 四.readOnly 五.rollbackFor 六.noRollbackFor Spring JdbcTemplate数据库事务参数 @Transactional() 注解里有不少参数,其

  • spring学习JdbcTemplate数据库事务管理

    目录 spring JdbcTemplate数据库事务管理 一.spring 中的事务管理 二.spring 事务管理 API 三.使用事务管理 1. 配置文件 2. 类上添加事务注解 spring JdbcTemplate数据库事务管理 现在有个账户表,里面存着用户金额. 如果要真正地做好转账的操作,就要用到事务,否则当出现异常后会出现数据不一致等问题. try { // 第一步 开启事务 // 第二步 进行业务操作 // 第三步 没有发生异常,提交事务 } catch(){ // 第四步 发

  • spring实现jdbctemplate添加事务支持示例

    复制代码 代码如下: public interface JdbcTemplate extends JdbcOperations {public abstract void beginTranstaion(); public abstract void commit(); public abstract void rollback();} 复制代码 代码如下: public class JdbcTemplateImpl extends org.springframework.jdbc.core.J

  • 关于Spring中声明式事务的使用详解

    目录 一.前言 二.回顾JDBC的数据库事务 三.数据库事务隔离级别 3.1 数据库事务的基本特征 3.2 详解数据库隔离级别 3.2.1 未提交读 3.2.2 读提交 3.2.3 可重复读 3.2.4 串行化 3.2.5 各个隔离级别的总结 四.数据库事务传播行为 五.Spring中的声明式事务的使用 5.1 @Transactional的配置属性 5.2 Spring的事务管理器 5.3 配置事务的传播行为和隔离级别 六.总结 一.前言 在Spring中,数据库事务是通过AOP技术来提供服务

  • 详解Spring学习之声明式事务管理

    前言 在前面的小节中,我们学习了关于事务的概念以及事务管理的重要性,并且通过编程使用Spring的编程式事务管理进行操作,加深对事务管理的重要性的学习,不过,由于编程式的事务管理使用起来不是很方便,所以在日常的开发中基本不怎么使用,接下来的内容我们将学习使用Spring的声明式事务管理,这里有一个地方需要明白的是,Spring的声明式事务管理的实现方式其实是通过AOP的方式来实现的,也就是为原始的事务管理对象创建代理对象,从而实现事务管理增强的 基于TransactionProxyFactory

  • 详解Spring学习之编程式事务管理

    前言 在前面的内容,基本已经学习了事务的基本概念以及事务隔离级别等,接下来的几个小节,将学习怎么使用Spring进行事务管理,在Spring中,对事务进行管理有多种方法,主要分别编程式和声明式,本小节主要学习编程式事务管理,后面讲学习Spring的声明式事务管理 编程式事务管理 所谓的编程式事务管理,其实就是通过编写代码的方式来进行事务管理,也就是通过将事务管理的代码硬编码在代码中从而达到事务管理的作用,不过Spring的事务管理不同于JDBC原始的事务管理,在JDBC中,对事务进行管理首先要关

  • 详解在Spring Boot中使用数据库事务

    我们在前面已经分别介绍了如何在spring Boot中使用JPA以及如何在Spring Boot中输出REST资源.那么关于数据库访问还有一个核心操作那就是事务的处理了,前面两篇博客小伙伴们已经见识到Spring Boot带给我们的巨大便利了,其实不用猜,我们也知道Spring Boot在数据库事务处理问题上也给我们带来惊喜,OK,废话不多说,就来看看如何在Spring Boot中使用事务吧. OK,那我们开始今天愉快的coding旅程吧! 创建Project并添加数据库依赖 这个没啥好说的,不

  • spring mvc 读取xml文件数据库配置参数的方法

    本文主要介绍怎么通过属性注入与构造器注入实现把我们项目中要用到的数据库参数放到xml文件里面去,方便部署. spring mvc 4.2.6项目 SQL Server 2008数据库 本文介绍的主要使用ApplicationContext以及其实现类实现.主要用到的是ClassPathXmlApplicationContext. ClassPathXmlApplicationContext:从类路径ClassPath中寻找指定的XML配置文件,找到并装载 完成ApplicationContext

  • Spring数据库事务的实现机制讲解

    目录 事务控制的核心--Connection 用AOP技术保持当前的Connection Service层和Dao层共享Connection 事务为什么要切在Service层的理由 spring事务与数据库事务的区别 事务控制的核心--Connection 在开始之前,先让我们回忆一下数据库较原始的JDBC是怎么管理事务的: //仅做演示,代码不完整,不完全规范 try { con.setAutoCommit(false); statement1 = con.prepareStatement(s

随机推荐