目录

数据库隔离级别和传播行为

目录

事务五个隔离级别

  • DEFAULT

使用数据库设置的隔离级别 ( 默认 ) ,由 DBA 默认的设置来决定隔离级别 .

  • READ_UNCOMMITTED

会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )

  • READ_COMMITTED

会出现不可重复读、幻读问题(锁定正在读取的行)

  • REPEATABLE_READ

会出幻读(锁定所读取的所有行)

  • SERIALIZABLE

保证所有的情况不会发生(锁表)

spring中七个事务传播行为

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

  • PROPAGATION_REQUIRED(默认的spring事务传播级别)

如果存在一个事务,则支持当前事务。如果没有事务则开启一个新的事务。

  • PROPAGATION_SUPPORTS

如果存在一个事务,支持当前事务。如果没有事务,则非事务的执行。但是对于事务同步的事务管理器,PROPAGATION_SUPPORTS与不使用事务有少许不同。

  • PROPAGATION_MANDATORY

如果已经存在一个事务,支持当前事务。如果没有一个活动的事务,则抛出异常。

  • PROPAGATION_REQUIRES_NEW

总是开启一个新的事务。如果一个事务已经存在,则将这个存在的事务挂起。

  • PROPAGATION_NOT_SUPPORTED

总是非事务地执行,并挂起任何存在的事务。

  • PROPAGATION_NEVER

总是非事务地执行,如果存在一个活动事务,则抛出异常

  • PROPAGATION_NESTED

如果一个活动的事务存在,则运行在一个嵌套的事务中. 如果没有活动事务, 则按TransactionDefinition.PROPAGATION_REQUIRED 属性执行