事务的隔离级别和锁机制

本文探讨了数据库事务处理中的关键概念,如不同隔离级别的作用(如读已提交防止脏读/幻读),锁机制(如悲观锁与乐观锁),以及死锁的条件和解决方案。重点在于理解事务处理在并发环境下的复杂性及应对策略。
摘要由CSDN通过智能技术生成

读未交:性能最好,工作不可能用

读已交:

可重复读:保证同一个事务读取相同的,是一样的

串行化: where区间锁 性能最低

悲观锁: fullupdate

乐观锁:cas机制 时间戳,版本号,

脏读:读到你还没有提交的数据

事务A读取商品表,修改商品,未commit

事务B开启事务读取商品表,读取到A对商品表修改的数据,此时A事务未commit

若A回滚,B读的是错误数据

解决方案:提升事务隔离级别:将读未提交,改为读已提交

不可重复读:

在两次读取数据中间有人改了数据

读未提交和读已提交均会有不可重复读的状况

幻读:

解决幻读,不可以通过串行化,失去并发能力,行锁无法锁住插入,可以锁住间隙,间隙锁和行锁的结合.

死锁条件:

在无外力干预的情况下无法断开

1.互斥条件:多个线程无法同时使用一个资源.

2.持有并等待,等待过程中不会释放已有资源

3.不可剥夺,在自己未完成之前,不可能释放

4.形成线程和资源之间请求和等待的环形图.(循环等待)

如果发生死锁就只能重新启动

解决方案:

1.一次性拿到所有资源(破坏.持有并等待)

2.占用资源的线程在进一步申请资源的时候如果拿不到,就释放已有的资源.(破坏不可剥夺)

3.让资源的使用有一个线性的关系(破坏循环等待)

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
事务隔离级别是指多个事务并发执行时,一个事务对其他事务的可见性和影响程度的控制。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:在当前事务的控制下执行一个嵌套事务,如果不存在当前事务,则创建一个新事务。嵌套事务可以独立提交或回滚,但在外部事务提交时才会生效。 通过选择合适的事务隔离级别和传播机制,可以确保事务的数据一致性、安全性和性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值