悲观锁及乐观锁

本文探讨了数据库中的并发不一致问题,包括脏读、丢失修改和不可重复读。接着介绍了悲观锁和乐观锁的概念。悲观锁通过数据库的锁机制保证数据完整性,可能导致性能下降;而乐观锁利用版本控制,在提交时检查冲突,不解决脏读问题。最后提到了进程互斥和同步的概念。
摘要由CSDN通过智能技术生成

一、三种典型不一致:
假设数据A=1
1.脏读:
-> T1读取A=1
-> T1修改写入A=2
-> T2读取A=2
-> T1rollback,即A=1
T2读取的数据是错误的

2.丢失修改
-> T1读取A=1
-> T2读取A=1
-> T1修改A=A+1=2
-> T2修改A=A+1=2
-> T1写A=2
-> T2写A=2
修改两次A+1,但是A的值只加1

3.不能重复读
-> T1读取A=1
-> T2读取A=1
-> T2修改并写入A=2
-> T1再次读取A=2
T1第一次读取和第二次读取值不同

二、悲观锁和乐观锁
1.悲观锁(独占锁)synchronized:
假定会发生并发冲突,屏蔽一切可能违反数据完整性的操作。
具有强烈的独占和排他特性。它指的是对数据被外界(包括本系统当前的其他事务,以及来自外部系统的事务处理)修改持保守态度,因此,在整个数据处理过程中,将数据处于锁

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值