事务

简介: 事务

先上要记住的结论:

事务隔离级别 脏写 脏读 丢失更新 不可重复读 幻读
读未提交(read-uncommitted) 可能 可能 可能 可能
不可重复读(read-committed) 可能 可能 可能
可重复读(repeatable-read) 可能
串行化(serializable)


什么是数据库事务

定义:数据库事务是构成单一逻辑工作单元的操作集合


事务的基本要素(ACID)

  1. 原子性(Atomicity): 事务开始后所有操作,要么全部做完,要么全部不做,不可能停滞在中间环节。事务执行过程中出错,会回滚到事务开始前的状态,所有的操作就像没有发生一样。也就是说事务是一个不可分割的整体,就像化学中学过的原子,是物质构成的基本单位。
  2. 一致性(Consistency): 事务开始前和结束后,数据库的完整性约束没有被破坏 。比如A向B转账,不可能A扣了钱,B却没收到。
  3. 隔离性(Isolation): 同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰。比如A正在从一张银行卡中取钱,在A取钱的过程结束前,B不能向这张卡转账。
  4. 持久性(Durability): 事务完成后,事务对数据库的所有更新将被保存到数据库,不能回滚。


ACID实现原理

在事务的ACID特性中, C即 一致性是事务的根本追求 , 而对数据一致性的破坏主要来自两个方面

  1. 事务的并发执行
  2. 事务故障或系统故障


数据库系统是通过 并发控制技术日志恢复技术 来避免这种情况发生的。


并发控制技术 保证了事务的隔离性, 使数据库的一致性状态不会因为并发执行的操作被破坏。


日志恢复技术 保证了事务的原子性, 使一致性状态不会因事务或系统故障被破坏。同时使已提交的对数据库的修改不会因系统崩溃而丢失, 保证了事务的持久性。

事务实现原理.png


事务并发问题

脏写

脏写是指事务回滚了其他事务对数据项的已提交修改, 比如下面这种情况:

事务1 事务2
read(A)=10
read(A)=10
write(A)=30
Commit
write(A)=20
Rollback(A=10)

在事务1对数据A的回滚, 导致事务2对A的已提交修改也被回滚了。


丢失更新

丢失更新是指事务覆盖了其他事务对数据的已提交修改, 导致这些修改好像丢失了一样。

事务1 事务2
read(A)=10
read(A)=10
A:=A+10
Commit
A:=A-10
Commit

事务1和事务2读取A的值都为10, 事务2先将A加上10并提交修改, 之后事务1将A减少10并提交修改, A的值最后为0, 导致事务2对A的修改好像丢失了一样。


脏读

脏读是指 一个事务读取了另一个事务未提交的数据

事务1 事务2
read(A)=10
A: A*2
write(A)
read(A)=20
rollback(A=10)

在事务1对A的处理过程中, 事务2读取了A的值, 但之后事务1回滚, 导致事务2读取的A是未提交的脏数据。


不可重复读

不可重复读是指一个事务对同一数据的读取结果前后不一致。脏读和不可重复读的区别在于: 前者读取的是事务未提交的脏数据, 后者读取的是事务已经提交的数据 , 只不过因为数据被其他事务修改过导致前后两次读取的结果不一样。

事务1 事务2
read(A)=10
read(A)=10
A: A*2
write(A)=20
commit
read(A)=20

由于事务2对A的已提交修改, 事务1前后两次读取的结果不一致。


幻读

幻读是指事务读取某个范围的数据时,因为其他事务的操作导致前后两次读取的结果不一致。幻读和不可重复读的区别在于, 不可重复读是针对确定的某一行数据而言, 而幻读是针对不确定的多行数据。因而幻读通常出现在带有查询条件的范围查询中。

事务1 事务2
read(A<5)=(1, 2, 3)
write(A)=4
Commit
read(A<5)=(1, 2, 3, 4)

事务1查询A<5的数据, 由于事务2插入了一条A=4的数据, 导致事务1两次查询得到的结果不一样


事务的隔离级别

  • 事务具有隔离性, 理论上来说事务之间的执行不应该相互产生影响, 其对数据库的影响应该和它们串行执行时一样。
  • 然而完全的隔离性会导致系统并发性能很低, 降低对资源的利用率, 因而实际上对隔离性的要求会有所放宽, 这也会一定程度造成对数据库一致性要求降低
  • SQL标准为事务定义了不同的隔离级别, 从低到高依次是
  • 读未提交 (READ UNCOMMITTED)
  • 读已提交 (READ COMMITTED)
  • 可重复读 (REPEATABLE READ)
  • 串行化 (SERIALIZABLE)


微信截图_20221208153428.png


事务的隔离级别越低, 可能出现的并发异常越多, 但是通常而言系统能提供的并发能力越强。

事务隔离级别 脏写 脏读 丢失更新 不可重复读 幻读
读未提交(read-uncommitted) 可能 可能 可能 可能
不可重复读(read-committed) 可能 可能 可能
可重复读(repeatable-read) 可能
串行化(serializable)

所有事务隔离级别都不允许出现脏写, 而串行化可以避免所有可能出现的并发异常, 但是会极大的降低系统的并发处理能力。

目录
相关文章
|
8月前
|
SQL 关系型数据库 MySQL
事务及事务的隔离级别
事务及事务的隔离级别
|
6月前
|
SQL Oracle 关系型数据库
第7章 事务
第7章 事务
37 0
|
8月前
|
存储 Java 中间件
事务一致性测试
事务一致性测试
65 0
|
8月前
|
SQL 前端开发 大数据
什么是大事务?以及大事务产生的问题
什么是大事务?以及大事务产生的问题
213 0
|
存储 Oracle 固态存储
深入理解事务
事务将应用程序的多个读、写操作捆绑在一起成为一个逻辑执行单元。即事务中的所有读写是一个执行的整体,整 个事务要么成功(提交)、要么失败(中止 或者 回滚)。如果失败,应用程序可以安全地重试。
16454 0
深入理解事务
|
人工智能 关系型数据库 MySQL
事务详解
事务是逻辑上的一组操作,要么都执行,要么都不执行。
83 0
|
SQL 存储 关系型数据库
|
SQL Java 大数据
事务详解(2)
你好看官,里面请!今天笔者讲的是事务。不懂或者觉得我写的有问题可以在评论区留言,我看到会及时回复。 注意:本文仅用于学习参考,不可用于商业用途,如需转载请跟我联系。
174 1
|
数据库
什么时候需要使用事务
什么时候需要使用事务
652 0
|
Oracle 安全 Java
事务详解(1)
你好看官,里面请!今天笔者讲的是事务。不懂或者觉得我写的有问题可以在评论区留言,我看到会及时回复。 注意:本文仅用于学习参考,不可用于商业用途,如需转载请跟我联系。
115 2