【事务隔离级别和传播机制】

事务隔离级别和传播机制

事务隔离级别:
在数据库中,事务隔离级别是指多个事务之间相互隔离的程度。常见的事务隔离级别有四个,从低到高依次是:

读未提交(Read Uncommitted):一个事务可以读取另一个事务修改但未提交的数据。最低级别,会产生脏读、不可重复读和幻读问题。
读已提交(Read Committed):一个事务只能读取另一个事务已经提交的数据。可以避免脏读问题,但可能会产生不可重复读和幻读问题。
可重复读(Repeatable Read):一个事务在执行过程中多次读取同一行数据,保证每次读取的数据都是一致的。可以避免脏读和不可重复读问题,但可能会产幻读问题。
串行化(Serializable):最高级别,强制事务串行执行,避免以上所有问题。

事务传播机制:

在 Spring 中,一个事务嵌套另一个事务执行时,就需要用到事务传播机制,它用来指定事务在不同方法间进行传播的行为。常见的事务传播机制有七种:

PROPAGATION_REQUIRED:默认的传播行为,表示如果当前没有事务,则新建一个事务,如果已经存在一个事务中,则加入到这个事务中执行。
PROPAGATION_SUPPORTS:表示如果当前存在事务,则加入这个事务,如果不存在事务,则以非事务的方式执行。
PROPAGATION_MANDATORY:表示当前必须存在一个事务,如果不存在,则抛出异常。
PROPAGATION_REQUIRES_NEW:表示当前必须启动一个新的事务,并在它自己的事务内执行,如果当前已经存在一个事务,则将当前事务挂起。
PROPAGATION_NOT_SUPPORTED:表示当前必须以非事务方式执行,如果存在事务,则将当前事务挂起。
PROPAGATION_NEVER:表示当前必须以非事务方式执行,如果存在事务,则抛出异常。
PROPAGATION_NESTED:表示当前事务必须在一个父事务中执行,如果当前不存在事务,则新建一个事务,如果已经存在事务,则在该事务中创建一个子事务。与 PROPAGATION_REQUIRES_NEW 的区别在于,它不是启动一个新事务,而是在已经存在的事务中创建一个子事务,主事务回滚同时影响子事务回滚,子事务会记录savepoint,子事务失败只会回滚到savepoint位置,不会影响主事务```
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
事务隔离级别是指多个事务并发执行时,一个事务对其他事务的可见性和影响程度的控制。Spring框架支持四个事务隔离级别: 1. 未提交读(READ UNCOMMITTED):最低级别,一个事务可以读取未提交的数据,会导致脏读,不可重复读和幻读问题的出现。 2. 提交读(READ COMMITTED):一个事务只能读取已提交的数据,可以避免脏读问题,但可能导致不可重复读和幻读问题。 3. 可重复读(REPEATABLE READ):在一个事务中多次读取同一数据时,结果保持一致,避免了不可重复读问题。但仍然可能存在幻读问题。 4. 串行化(SERIALIZABLE):最高级别,通过确保事务串行执行来避免脏读、不可重复读和幻读问题。但会降低并发性能。 传播机制是指在调用多个事务方法时,如何处理事务传播。Spring框架提供七种传播行为: 1. REQUIRED:如果当前没有事务,就创建一个新事务;如果已存在事务,则加入该事务。 2. SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方法执行。 3. MANDATORY:强制要求存在当前事务,如果没有事务就抛出异常。 4. REQUIRES_NEW:创建一个新事务,并暂停当前事务(如果有)。 5. NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,则将其挂起。 6. NEVER:以非事务方式执行操作,如果当前存在事务,则抛出异常。 7. NESTED:在当前事务的控制下执行一个嵌套事务,如果不存在当前事务,则创建一个新事务。嵌套事务可以独立提交或回滚,但在外部事务提交时才会生效。 通过选择合适的事务隔离级别传播机制,可以确保事务的数据一致性、安全性和性能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值