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 默认:读已提交


五、事务操作

打开事务

提交事务

回滚事务

阅读全文
0 0
原创粉丝点击