zoukankan      html  css  js  c++  java
  • spring事物传播机制和隔离级别

    7种事务的传播机制(可通过spring配置或注解来设置)

    1. REQUIRED(默认):支持使用当前事务,如果当前事务不存在,创建一个新事务。
    2. SUPPORTS:支持使用当前事务,如果当前事务不存在,则不使用事务。
    3. MANDATORY:中文翻译为强制,支持使用当前事务,如果当前事务不存在,则抛出Exception。
    4. REQUIRES_NEW:创建一个新事务,如果当前事务存在,把当前事务挂起。
    5. NOT_SUPPORTED:无事务执行,如果当前事务存在,把当前事务挂起。
    6. NEVER:无事务执行,如果当前有事务则抛出Exception。
    7. NESTED:嵌套事务,如果当前事务存在,那么在嵌套的事务中执行。如果当前事务不存在,则表现跟REQUIRED一样。

    注解配置时如:@Transactional(propagation=Propagation.REQUIRED) 

    四种隔离级别

    注解配置时如:@Transactional(isolation = Isolation.READ_UNCOMMITTED)

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

    其中:可重复读(repeatable-read)表示:在开始读取数据(事务开启)时,不再允许修改操作

    mysql默认的事务隔离级别为repeatable-read

    事务的并发问题

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

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

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

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

  • 相关阅读:
    CodeForces 706C Hard problem
    CodeForces 706A Beru-taxi
    CodeForces 706B Interesting drink
    CodeForces 706E Working routine
    CodeForces 706D Vasiliy's Multiset
    CodeForces 703B Mishka and trip
    CodeForces 703C Chris and Road
    POJ 1835 宇航员
    HDU 4907 Task schedule
    HDU 4911 Inversion
  • 原文地址:https://www.cnblogs.com/KdeS/p/12410447.html
Copyright © 2011-2022 走看看