zoukankan      html  css  js  c++  java
  • 事务的传播机制

    事务传播机制

    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改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。

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

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

  • 相关阅读:
    POJ 2018 二分
    873. Length of Longest Fibonacci Subsequence
    847. Shortest Path Visiting All Nodes
    838. Push Dominoes
    813. Largest Sum of Averages
    801. Minimum Swaps To Make Sequences Increasing
    790. Domino and Tromino Tiling
    764. Largest Plus Sign
    Weekly Contest 128
    746. Min Cost Climbing Stairs
  • 原文地址:https://www.cnblogs.com/liuyiyuan/p/13039355.html
Copyright © 2011-2022 走看看