Spring 事务操作

一、事务(概念)

1. 什么是事务

  1. 事务是数据库的最基本单元,逻辑上的一组操作,要么都成功,如果有一个失败,那么所有的操作都失败
  2. 典型场景:
    • lucy转账100元给mary
    • lucy少100元,mary多100元

2. 事务的四个特性(ACID)

  1. 原子性(Atomicity)

  2. 一致性(Consistency)

  3. 隔离性(Isolation)

  4. 持久性(Durability)

二、事务操作

1. Spring事务管理介绍

  1. 事务添加到JavaEE三层结构里面Service层(业务逻辑层)

  2. 在Spring进行事务管理操作

    1. 编程式事务管理:就是在代码中编写代码,手动开启事务
    2. 声明式事务管理:面向切面配置事务,开启事务
  3. 声明式事务管理

    1. 基于注解方式(使用)
    2. 基于xml配置文件方式
  4. 在Spring进行声明式事务管理,底层使用AOP原理

  5. Spring事务管理API

    • 提供一个接口,代表事务管理器,这个接口针对不同的框架提供不同的实现类

2. 注解声明式事务管理

  1. 在Spring配置文件配置事务管理器

    <!-- 创建事务管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <!-- 注入数据源 -->
    <property name="dataSource" ref="dataSource"></property>
    </bean>
  2. 在Spring配置文件,开启事务注解

    1. 在spring配置文件引入名称空间tx

      <?xml version="1.0" encoding="UTF-8"?>
      <beans xmlns="http://www.springframework.org/schema/beans"
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xmlns:context="http://www.springframework.org/schema/context"
      xmlns:aop="http://www.springframework.org/schema/aop"
      xmlns:tx="http://www.springframework.org/schema/tx"
      xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
      http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
      http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
      http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">
    2. 开启事务注解

      <!-- 开启事务注解 -->
      <tx:annotation-driven transaction-manager="transactionManager"></tx:annotation-driven>
  3. 在service类什么(或者service类里面的方法上面)添加事务注解

    1. @Transaction,这个注解添加到类上面,也可以添加方法上面

    2. 如果把这个注解添加到类上面,这个类里面多有的方法都添加事务

    3. 如果把这个注解添加到方法上面,那么只是为这个方法添加事务

      @Service
      @Transaction
      public class UserService {
      ...
      }

3. 声明式事务管理参数配置

  1. 在service类声明添加注解@Transaction,这个注解里面可以配置事务相关参数

  2. propagation:事务传播行为

    1. 事务传播行为:多事务方法直接进行调用,这个过程中事务是如何进行管理的

    2. 事务方法:对数据库表的书籍进行变化的操作

    3. Spring框架事务传播行为有7种,重点掌握REQUIREDREQUIRES_NEW

      • REQUIRED:如果add方法本身有事务,调用update方法后,update使用当前add方法里面的事务;如果add方法本身没有事务,那么调用update方法之后,创建新事务

      • REQUIRES_NEW:使用add方法调用update方法,无论add方法是否有事务,update都要创建新事务,如果add方法的事务正在运行,那么update方法的事务要先挂起

  3. isolation:事务隔离级别

    1. 事务有特性成为隔离性,多事务之间操作不会产生影响。如果不考虑隔离性则会产生很多问题
    2. 有三个问题:脏读、不可重复读、幻读
    3. 脏读:在一个事务种读取到另一个未提交事务的数据

    1. 不可重复读:在一个事务种,两次查询到的结果不一致(针对update操作)

    1. 幻读:在一个事务种,两次查询到的结果不一致(针对insert操作)

    2. 如何解决这些问题?

      • 通过设置事务隔离级别,解决读问题

      • SQL标准的事务隔离级别包括:读未提交、读提交、可重复读(MySQL中默认)、串行化

        • 读未提交:一个事务还没提交时,它做的变更就能被别的事务看到
        • 读已提交:一个事务提交之后,它做的变更才能被其他事务看到
        • 可重复读:一个事务执行过程中看到的数据,总是跟这个事务在启动时看到的数据是一致的
        • 串行化:对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出像读写锁冲突时候,后访问的事务必须等前一个事务执行完成,才能继续执行

  4. timeout:超时时间

    • 事务需要在一定的时间内进行提交,如果不提交则进行回滚
    • 默认值是-1,设置时间以秒单位进行计算
  5. readOnly:是否只读

    • 读:查询操作 写:添加、修改、删除
    • readOnly默认值是false,表示可以读,也可以写
    • readOnly设置成true,只能进行读操作,即查询
  6. rollbaclFor:回滚

    • 设置出现哪些异常进行事务回滚
  7. noRollbackFor:不回滚

    • 设置出现哪些异常不进行事务回滚

4. XML声明式事务管理

  • 在Spring配置文件中进行配置

    1. 配置事务管理器

      <!-- 1. 创建事务管理器 -->
      <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
      <property name="dataSource" ref="dataSource"></property>
      </bean>
    2. 配置通知

      <!-- 2. 配置通知 -->
      <tx:advice id="txadvice">
      <!-- 配置事务参数 -->
      <tx:attributes>
      <tx:method name="accountMoney" propagation="REQUIRED"/>
      </tx:attributes>
      </tx:advice>
    3. 配置切入点和切面

      <!-- 3. 配置切入点和切面 -->
      <aop:config>
      <!-- 配置切入点 -->
      <aop:pointcut id="pt" expression="execution(* com.atguigu.spring5.service.UserService.*(..))"/>
      <!-- 配置切面 -->
      <aop:advisor advice-ref="txadvice" pointcut-ref="pt"/>
      </aop:config>

5. 完全注解声明式事务管理

  • 创建配置类

    @Configuration // 配置类
    @ComponentScan(basePackages = "com.atguigu") // 开启组件扫描
    @EnableTransactionManagement // 开启事务
    public class TxConfig { @Bean
    public DruidDataSource getDruidDataSource() {
    DruidDataSource druidDataSource = new DruidDataSource(); druidDataSource.setDriverClassName("com.mysql.jdbc.Driver");
    druidDataSource.setUrl("jdbc:mysql://localhost:3306/spring");
    druidDataSource.setUsername("root");
    druidDataSource.setPassword("16887988hhh."); return druidDataSource;
    } // 创建JdbcTemplate对象
    @Bean(value = "jdbcTemplate")
    public JdbcTemplate getJdbcTemplate(DataSource dataSource) {
    JdbcTemplate jdbcTemplate = new JdbcTemplate(); jdbcTemplate.setDataSource(dataSource); return jdbcTemplate;
    } // 创建事务管理器
    @Bean
    public DataSourceTransactionManager getDataSourceTransactionManager(DataSource dataSource) {
    DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager(); dataSourceTransactionManager.setDataSource(dataSource); return dataSourceTransactionManager;
    }
    }

Spring笔记(五)的更多相关文章

  1. Spring 笔记 -06- 从 MySQL 建库到 登录验证数据库信息(maven)

    Spring 笔记 -06- 从 MySQL 建库到 登录验证数据库信息(maven) 本篇和 Spring 没有什么关系,只是学习 Spring,必备一些知识,所以放在这里了. 本篇内容: (1)M ...

  2. C#可扩展编程之MEF学习笔记(五):MEF高级进阶

    好久没有写博客了,今天抽空继续写MEF系列的文章.有园友提出这种系列的文章要做个目录,看起来方便,所以就抽空做了一个,放到每篇文章的最后. 前面四篇讲了MEF的基础知识,学完了前四篇,MEF中比较常用 ...

  3. 《MFC游戏开发》笔记五 定时器和简单动画

    本系列文章由七十一雾央编写,转载请注明出处. http://blog.csdn.net/u011371356/article/details/9332377 作者:七十一雾央 新浪微博:http:// ...

  4. (转)Qt Model/View 学习笔记 (五)——View 类

    Qt Model/View 学习笔记 (五) View 类 概念 在model/view架构中,view从model中获得数据项然后显示给用户.数据显示的方式不必与model提供的表示方式相同,可以与 ...

  5. java之jvm学习笔记五(实践写自己的类装载器)

    java之jvm学习笔记五(实践写自己的类装载器) 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和第四节我们一直在强调一句话,类 ...

  6. Crazyflie笔记五: CRTP 实时通信协议(一)(转)

    源:Crazyflie笔记五: CRTP 实时通信协议(一) 这里详细介绍了 Crazyflie 的 CRTP实时通信协议的相关内容,由于内容很长,分几篇博文来讲述.这里是第一节内容.欢迎交流:301 ...

  7. Learning ROS for Robotics Programming Second Edition学习笔记(五) indigo computer vision

    中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...

  8. Spring笔记02_注解_IOC

    目录 Spring笔记02 1. Spring整合连接池 1.1 Spring整合C3P0 1.2 Spring整合DBCP 1.3 最终版 2. 基于注解的IOC配置 2.1 导包 2.2 配置文件 ...

  9. Spring笔记01_下载_概述_监听器

    目录 Spring笔记01 1.Spring介绍 1.1 Spring概述 1.2 Spring好处 1.3 Spring结构体系 1.4 在项目中的架构 1.5 程序的耦合和解耦 2. Spring ...

  10. Typescript 学习笔记五:类

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

随机推荐

  1. Jamstack Conf 2020

    Jamstack Conf 2020 Jamstack Conf Virtual https://jamstackconf.com/virtual/ Conf Schedule https://jam ...

  2. SVG animation(text, background)

    SVG animation(text, background) demo https://www.happyelements.com/ LICEcap bug Giphy 低帧率 gif https: ...

  3. js 动态构建style

    使用创建style的方式 btn.addEventListener("click", async () => { const ns = document.createElem ...

  4. Dart: 请求graphql数据

    import 'package:http/http.dart' as http; const url = "http://127.0.0.1:4000/graphql"; main ...

  5. NGK以强大的创新能力赋予NGK公链超级实用的特性

    公链从大趋势看是一个不断迭代的过程,不管是共识算法.网络架构.开发者协议都在一代一代不断完善跟创新. NGK公链作为公链赛道上的后起之秀,对于主流公链技术的局限性以及下一代公链技术的发展方向都有非常清 ...

  6. 【PY从0到1】 一文掌握Pandas量化基础

    # 2[PY从0到1] 一文掌握Pandas量化基础 # Numpy和pandas是什么关系呢? # 在我看来,np偏向于数据细节处理,pd更偏向于表格整体的处理. # 要记住的pd内部的数据结构采用 ...

  7. 发布Jar包到maven中央仓库

    什么是maven中央仓库 maven是java世界最流行的构建工具,构建内容囊括了一个java项目的整个生命周期.其中最重要的功能就是依赖管理,maven通过一个类似云的ftp站点统一管理所有java ...

  8. Nifi组件脚本开发—ExecuteScript 使用指南(二)

    Part 2 - FlowFile I/O 和 Error Handling flow File的IO NiFi 的 Flow files 由两个主要部件组成:attributes 和 content ...

  9. 安装mysql报错

    原文链接:https://blog.csdn.net/bao19901210/article/details/51917641 二进制安装 1.添加mysql组和mysql用户,用于设置mysql安装 ...

  10. Vue学习笔记-vue-element-admin 前端学习

    一  使用环境 开发系统: windows 后端IDE: PyCharm 前端IDE: VSCode 数据库: msyql,navicat 编程语言: python3.7  (Windows x86- ...