博客
关于我
Spring事务传播属性和隔离级别
阅读量:316 次
发布时间:2019-03-03

本文共 1427 字,大约阅读时间需要 4 分钟。

Spring事务传播属性和隔离级别

Spring事务传播属性(Propagation)

在Spring中,事务传播属性决定了如何处理方法调用的事务关系。默认情况下,Spring使用REQUIRED属性,这表示如果存在一个已经激活的事务,当前方法会支持这个事务;如果没有事务,则会开启一个新的事务。这种传播方式确保了每个方法调用的逻辑事务域是独立的,前后方法之间不会互相影响。

传播属性的具体实现

  • REQUIRED(默认):如果有活性的事务存在,当前方法会参与这个事务;如果没有,则新建一个独立的事务。
  • MANDATORY:要求当前方法必须参与已有的事务。如果没有活性的事务,会抛出TransactionRequiredException
  • NEVER:禁止当前方法参与任何事务。如果有活性的事务,会抛出TransactionException
  • NOT_SUPPORTED:禁止当前方法参与事务。如果有活性的事务,会暂停当前事务并以非事务模式执行。
  • REQUIRES_NEW:强制创建新的事务。如果有活性的事务,会暂停当前事务并启动一个新的事务。
  • SUPPORTS:支持当前事务,如果没有活性事务,则以非事务模式执行。
  • NESTED:支持嵌套事务,与当前事务共享一个Savepoint,确保嵌套事务的提交与外层事务同步。
  • 传播属性的区别

    • REQUIRES_NEWNESTED:它们都要求新建事务,但REQUIRES_NEW创建的是独立的事务,外层事务无法回滚内层事务;而NESTED创建的是嵌套事务,外层事务的回滚会影响内层事务。

    传播属性的意义

    选择正确的事务传播属性对于应用程序的行为至关重要。例如,使用REQUIRES_NEW可以确保不同方法调用的事务相互独立,而NESTED则允许细粒度的控制,最大限度地利用已有的事务资源。


    Spring事务隔离级别(Isolation Level)

    事务的隔离级别决定了在并发环境下如何处理事务的读写冲突。不同的隔离级别提供了不同的并发控制机制,防止并发事务导致的数据不一致。

    并发问题

  • 脏读(Dirty Reads):一个事务读取未提交的数据,可能看到其他事务的修改。
  • 不可重复读(Non-Repeatable Reads):一个事务多次读取同一数据,结果受到其他事务修改的影响。
  • 幻像读(Phantom Reads):一个事务多次读取同一数据,结果受到其他事务插入的影响。
  • 隔离级别

  • DEFAULT(默认):使用数据库的默认隔离级别,通常为READ_COMMITTED
  • READ_UNCOMMITTED:最低隔离级别,允许读取未提交的事务数据,会导致脏读。
  • READ_COMMITTED:确保读取的数据是已提交的事务数据,避免脏读,但仍可能出现不可重复读。
  • REPEATABLE_READ:防止脏读和不可重复读,允许同一事务多次读取相同数据。
  • SERIALIZABLE:最高隔离级别,确保事务按顺序执行,防止任何形式的数据不一致。
  • 隔离级别的意义

    选择合适的隔离级别需要权衡数据一致性和性能。SERIALIZABLE虽然可靠,但会显著增加系统开销;而REPEATABLE_READ提供了较好的性能和数据一致性。


    通过合理配置事务传播属性和隔离级别,可以有效管理多个事务之间的关系,确保系统的数据一致性和高可用性。在实际应用中,需要根据业务需求选择最适合的隔离级别和传播属性,以实现高效且安全的事务管理。

    转载地址:http://sigl.baihongyu.com/

    你可能感兴趣的文章
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    MySQL 导出数据
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
    查看>>
    MySQL 快速创建千万级测试数据
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>