码迷,mamicode.com
首页 > 其他好文 > 详细

事务的传播机制

时间:2020-06-03 18:51:04      阅读:74      评论:0      收藏:0      [点我收藏+]

标签:操作   new   tor   结果   sam   body   not   系统管   一个   

事务传播机制

spring在TransactionDefinition接口中定义了七个事务传播行为:

  1. propagation_requierd:如果当前没有事务,就新建一个事务,如果已存在一个事务中,加入到这个事务中,这是最常见的选择。
  2. propagation_supports:支持当前事务,如果没有当前事务,就以非事务方法执行。
  3. propagation_mandatory:使用当前事务,如果没有当前事务,就抛出异常。
  4. propagation_required_new:新建事务,如果当前存在事务,把当前事务挂起。
  5. propagation_not_supported:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
  6. propagation_never:以非事务方式执行操作,如果当前事务存在则抛出异常。
  7. propagation_nested:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与propagation_required类似的操作

 四种隔离级别

事务隔离级别 脏读 不可重复读 幻读
读未提交(Read-Uncommitted)
读已提交(Read-Committed)
可重复读(Repeatable-Read)
串行化(Serializable)

 

mysql默认的事务隔离级别为Repeatable-Read, Innodb引擎支持事务,MyIsam引擎不支持事务。mysql实现可重复读的方式为第一次读取数据后保存一个快照,以后直接读快照,所以也叫快照读。

orcale默认的事务隔离级别为Read-Committed

事务的并发问题

  1、脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据

  2、不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果 不一致。

  3、幻读:系统管理员A将数据库中所有学生的成绩从具体分数改为ABCDE等级,但是系统管理员B就在这个时候插入了一条具体分数的记录,当系统管理员A改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。

 

脏读会产生错误数据,是不可允许的,不可重复读与幻读是在多次读取中数据发生了变化,数据是有效的。

不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表

事务的传播机制

标签:操作   new   tor   结果   sam   body   not   系统管   一个   

原文地址:https://www.cnblogs.com/liuyiyuan/p/13039355.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!