SSH与SSM学习之Spring19——Spring事务之事务基础
来源:互联网 发布:nginx lua 开发环境 编辑:程序博客网 时间:2024/05/22 10:27
- SSH与SSM学习之Spring19Spring事务之事务基础
- 一事务概念
- 二事务特性
- 1 原子性
- 2 一致性
- 3 隔离性
- 4 持久性
- 三事务并发问题
- 四解决读问题设置事务隔离级别
- 五事务操作
SSH与SSM学习之Spring19——Spring事务之事务基础
一、事务概念
事务是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。
事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。
二、事务特性
事务特性 acid
2.1 原子性
(Atomic)(Atomicity)
事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。通常,与某个事务关联的操作具有共同的目标,并且是相互依赖的。如果系统只执行这些操作的一个子集,则可能会破坏事务的总体目标。原子性消除了系统处理操作子集的可能性。
2.2 一致性
(Consistent)(Consistency)
事务在完成时,必须使所有的数据都保持一致状态。在相关数据库中,所有规则都必须应用于事务的修改,
以保持所有数据的完整性。事务结束时,所有的内部数据结构(如 B 树索引或双向链表)都必须是正确的。
某些维护一致性的责任由应用程序开发人员承担,他们必须确保应用程序已强制所有已知的完整性约束。
例如,当开发用于转帐的应用程序时,应避免在转帐过程中任意移动小数点。
2.3 隔离性
(Insulation)(Isolation)
由并发事务所作的修改必须与任何其它并发事务所作的修改隔离。事务查看数据时数据所处的状态,
要么是另一并发事务修改它之前的状态,要么是另一事务修改它之后的状态,事务不会查看中间状态的数据。
这称为隔离性,因为它能够重新装载起始数据,并且重播一系列事务,以使数据结束时的状态与原始事务
执行的状态相同。当事务可序列化时将获得最高的隔离级别。在此级别上,从一组可并行执行的事务获得
的结果与通过连续运行每个事务所获得的结果相同。由于高度隔离会限制可并行执行的事务数,所以一些
应用程序降低隔离级别以换取更大的吞吐量。
2.4 持久性
(Duration)(Durability)
事务完成之后,它对于系统的影响是永久性的。该修改即使出现致命的系统故障也将一直保持。
三、事务并发问题
脏读 :一个事务读到了另一个事务的未提交的数据
不可重复读 :一个事务读到了另一个事务已经提交的 update 的数据导致多次查询结果不一致.
虚|幻读 :一个事务读到了另一个事务已经提交的 insert 的数据导致多次查询结果不一致.
四、解决读问题:设置事务隔离级别
未提交读 :脏读,不可重复读,虚读都有可能发生
已提交读 :避免脏读。但是不可重复读和虚读有可能发生
可重复读 :避免脏读和不可重复读.但是虚读有可能发生.
串行化的 :避免以上所有读问题
Mysql 默认:可重复读
Oracle 默认:读已提交
五、事务操作
打开事务
提交事务
回滚事务
- SSH与SSM学习之Spring19——Spring事务之事务基础
- SSH与SSM学习之Spring20——Spring事务之Spring相关的基础
- SSH与SSM学习之Spring22——Spring事务之xml配置方式管理事务
- SSH与SSM学习之Spring23——Spring事务之注解配置方式管理事务
- SSH与SSM学习之SSH整合09——Spring的aop事务
- SSH与SSM学习之Spring21——Spring事务之代码方式管理事务(基本不用)
- SSH与SSM学习之hibernate12——hibernate中的事务
- SSH与SSM学习之SSH整合04——Struts2与Spring整合
- SSH与SSM学习之SSH整合06——Hibernate与Spring整合
- SSH与SSM学习之SSH整合02——单独配置Spring容器
- SSH与SSM学习之SSH整合07——Spring整合c3p0连接池
- SSH与SSM学习之SSH整合08——Spring整合Hibernate环境操作数据库
- SSH与SSM学习之Spring04——Spring属性注入之set方法注入
- SSH与SSM学习之Spring05——Spring属性注入之构造函数注入
- SSH与SSM学习之Spring06——Spring属性注入之p名称空间注入
- SSH与SSM学习之Spring07——Spring属性注入之spel注入
- SSH与SSM学习之Spring08——Spring属性注入之复杂类型注入
- SSH与SSM学习之Spring16——Spring中AOP之使用配置文件配置
- 杨氏矩阵
- 快速排列初识
- 欢迎使用CSDN-markdown编辑器
- 点乘和叉乘
- (EX)CRT+(EX)Lucas BZOJ2142
- SSH与SSM学习之Spring19——Spring事务之事务基础
- 检索模型评价指标
- 插入排序
- eclipse快捷键冲突
- 2017.11.1总结
- #49 图形输出3 心得体会
- C++——【USACO 5.4.3】——Telecowmunication
- 方程求解
- N皇后算法—优化版