Spring总结九:事务管理机制
何为事务
事务(Transaction),一般是指要做的或所做的事情。在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。事务通常由高级数据库操纵语言或编程语言(如SQL,C++或Java)书写的用户程序的执行所引起,并用形如begin transaction和end transaction语句(或函数调用)来界定。事务由事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。
简单来说就是一组通过程序操作数据库的操作,要么全部成功,要么全部失败。
事务的ACID四大特性:
原子性(Atomicity):事务是一个原子操作,由一系列动作组成。事务的原子性确保动作要么全部完成,要么完全不起作用。
一致性(Consistency):一旦事务完成(不管成功还是失败),系统必须确保它所建模的业务处于一致的状态,而不会是部分完成部分失败。在现实中的数据不应该被破坏。
隔离性(Isolation):可能有许多事务会同时处理相同的数据,因此每个事务都应该与其他事务隔离开来,防止数据损坏。
持久性(Durability):一旦事务完成,无论发生什么系统错误,它的结果都不应该受到影响,这样就能从任何系统崩溃中恢复过来。通常情况下,事务的结果被写到持久化存储器中。
Spring事务管理的三个高层接口:
1,PlatformTransactionManager 平台相关事务管理器
TransactionManager是整个spring事务管理核心对象,提供管理事务相关方法
项目开发时,使用不同持久层技术,就需要使用spring提供不同事务管理器 JDBC编程 --- 通过Connection进行事务管理 开启事务 conn.setAutoCommit(false); 提交事务 conn.commit(); 回滚事务 conn.rollback();、 conn.rollback(SavePoint ); Spring 提供 DataSourceTransactionManager 针对Connection进行事务管理 Spring 提供 HibernateTransactionManager 针对 session进行事务管理
2,TransactionDefinition 事务定义信息 (在使用spring管理事务,对事务管理配置信息 )
TransactionDefinition 主要指 spring管理事务过程中,配置如何对事务进行管理
(隔离级别、传播行为、超时时间、 是否只读)
get Name 获取事务名称 getIsolationLevel 获取事务隔离级别
脏读:一个事务读取另一个事务 未提交的数据 ---- 非常严重安全问题 不可重复读:一个事务读取另一个事务已经提交数据,先后读取两次,结果不一样(另一个事务进行update操作) 幻读:一个事务中先后读取两次,发现数据记录条数不一样(另一个事务进行insert操作 )
数据库为了解决 隔离性引发几种问题,提供四种隔离级别
read uncommitted 引发所有隔离问题、
read committed 阻止脏读发生、发生不可重复读和幻读、
repeatable read 阻止脏读、不可重复读发生,可能发生幻读、
serializable 阻止所有隔离问题
不是所有数据库都支持四种隔离级别, oracle只支持 read committed、serializable ; mysql支持所有隔离级别
DEFAULT 代表默认数据库隔离级别,oracle 默认级别 read committed、 mysql 默认级别 repeatable read
getPropagationBehavior 获取事务的传播行为
什么是传播行为?
和隔离级别不同,不是数据库提供问题解决方案,而是spring针对实际开发中具体事务问题,引入事务解决方案,解决两个事务互相调用的问题 !
Spring为了解决上面的问题,提供七种传播行为
REQUIRED、SUPPORTS、MANDATORY:支持当前事务 (删除用户、删除订单) 操作同一事务
REQUIRES_NEW、NOT_SUPPORTED、NEVER:不支持当前事务 (ATM取钱、打印凭条) 操作不同事务
NESTED 嵌套事务,只对DataSourceTransactionManager 有效,底层原理SavePoint 一个事务,允许回滚到事务中的某个保存的点,然后继续执行
3,TransactionStatus 事务运行状态
指事务运行过程中,某个时间点事务状态信息
用户想使用spring进行事务管理 ,对事务管理进行配置(TransactionDefinition),选用针对持久层技术事务管理器 TransactionManager, TransactionManager根据TransactionDefinition 进行事务管理,在事务管理过程中通过 TransactionStatus获取当时事务状态 。
Spring事务管理的两种方式:
1、 编程式事务管理,在需要事务管理目标代码中,添加事务管理的代码 (有代码侵入事务管理方式 ,现在使用的非常少 )
在spring配置TransactionManager ,将transactionManager对象注入到 TransactionTemplate 对象中,将transactionTemplate 注入到目标程序中
transactionTemplate.execute(new TransactionCallbackWithoutResult(){
doInTransaction(){
// 将需要事务管理代码,加在这里
}
});
如果方法没有异常,事务提交,如果方法发生异常,事务回滚
2、 声明式事务管理,底层使用AOP的环绕通知,没有任何代码侵入,现在开发中推荐使用 。
-----------------------------------------------------------下一篇写简单案例
Spring总结九:事务管理机制的更多相关文章
- Spring入门5.事务管理机制
Spring入门5.事务管理机制 20131126 代码下载 : 链接: http://pan.baidu.com/s/1kYc6c 密码: 233t 回顾之前的知识,Spring 最为核心的两个部分 ...
- Spring事务管理机制的实现原理-动态代理
之前在做项目中遇到spring无法进行事务代理问题,最后发现是因为没有写接口,原因当时明白了,看到这篇文章写的清楚些,转过来 我们先来分析一下Spring事务管理机制的实现原理.由于Spring内置A ...
- spring 事务管理机制
1. spring 事务管理抽象 spring 的事务策略机制的核心就是 org.springframework.transaction.PlatformTransactionManager 接口. ...
- Spring入门6事务管理2 基于Annotation方式的声明式事务管理机制
Spring入门6事务管理2 基于Annotation方式的声明式事务管理机制 201311.27 代码下载 链接: http://pan.baidu.com/s/1kYc6c 密码: 233t 前言 ...
- Spring 框架基础(05):事务管理机制,和实现方式
本文源码:GitHub·点这里 || GitEE·点这里 一.Spring事务管理 1.基础描述 Spring事务管理的本质就是封装了数据库对事务支持的操作,使用JDBC的事务管理机制,就是利用jav ...
- [转]Spring3核心技术之事务管理机制
原文地址:http://chouyi.iteye.com/blog/1675199 Spring对事务的解决办法其实分为2种:编程式实现事务,AOP配置声明式解决方案. http://jinnians ...
- Spring学习8-Spring事务管理(编程式事务管理)
一.Spring事务的相关知识 1.事务是指一系列独立的操作,但在概念上具有原子性. 比如转账:A账号-100, B账号+100,完成.这两个操作独立是没问题的. 但在逻辑上,要么全部完成,要么一 ...
- Spring对Hibernate事务管理
谈Spring事务管理之前我们想一下在我们不用Spring的时候,在Hibernate中我们是怎么进行数据操作的.在Hibernate中 我们每次进行一个操作的的时候我们都是要先开启事务,然后进行数据 ...
- Spring中的事务管理
事务简介: 事务管理是企业级应用程序开发中必不可少的技术,用来确保数据的完整性和一致性 事务就是一系列的动作,它们被当作一个单独的工作单元.这些动作要么全部完成,要么全部不起作用 事务的四个关键属性( ...
随机推荐
- *Fragment与Activity生命周期的协调
本文出处:http://blog.csdn.net/think_soft/article/details/7272869 拥有Fragment的Activity的生命周期直接影响了其中的Fragmen ...
- ROS机器人星火计划公开课总结
非常荣幸参加了两次星火计划公开课(上海站), 感谢NXROBO.EXBOT以及所有支持ROS机器人星火计划的小伙伴们. ----废话开始,与课程总结无关,可跳过---- 在国内20多年的求学生涯以及2 ...
- Python中实现装饰模式的三种方式
功能目标 编写一个可以打印被装饰函数名称.执行时间.内存地址得装饰器 前置依赖包 import time import functools from decorator import decorato ...
- InnoDB MVCC RR隔离级别下的数据可见性总结
一.背景 熟悉数据库隔离级别的人都知道,在RR(可重复读)隔离级别下,无论何时多次执行相同的SELECT快照读语句,得到的结果集都是完全一样的,即便两次SELECT语句执行期间,其他事务已经改变了该查 ...
- 【python】socket
UDP udp_server.py from datetime import datetime import socket server_address = ('localhost', 6789) m ...
- 第一章 Oracle10g数据库新特性
1.1 Oracle10g数据库概述 1.1.1 网格数据库 Oracle10g数据库是一种为网格计算而设计的数据库,是第一个用完整集成的软件基础架构来实现网络计算的数据库系统,其中10g的g表示gr ...
- python库之selectors
在之前的博客中已经总结过分别在windows和linux操作系统下实现socket高并发(I/O异步)的方法,可以参考基于epoll的TP传输层实现和Windows之IOCP 下面对Python中实现 ...
- 分布式使用Redis
为什么我们做分布式使用Redis? https://www.cnblogs.com/yaodengyan/p/9717080.html 绝大部分写业务的程序员,在实际开发中使用 Redis 的时候,只 ...
- Java基础总结大全
一.基础知识: 1.JVM.JRE和JDK的区别: JVM(Java Virtual Machine):java虚拟机,用于保证java的跨平台的特性. java语言是跨平台,jvm不是跨平台的. J ...
- avalon 总线时序关系理解
对于读,等待时间指的是从端口捕获数据的时间相对于read信号的延时 建立时间指的是read信号相对于chipselect和addr的延时时间 对于写,等待时间指的是相对于非等待情况下各个信号的延时时间 ...