事务并发——并发控制(加锁)

事务处理中的并发控制:
1. 并发操作
数据库是一个共享资源,允许多个用户程序并行地存取数据库,所以当多个用户并发地存取同一数据,就可能出现数据的不一致性。例如:假设有两个事务 T1 T2 ,它们都需要读出并修改数据 A ,其执行情况如下所示:
执行顺序
1
2
3
4
5
6
事务 T1
A
A=A+10
 
提交 A
 
提交 A
事务 T2
 
 
A
 
A =A-30
 
T1 工作区中 A 的值
30
40
40
40
40
40
T2 工作区中 A 的值
 
30
30
30
0
0
数据库中 A 的值
30
30
30
40
40
0
2. 导致结果
正常情况下最后数据库中 A 的值应该是 10 ,可结果确是 0
3. 产生原因
由于事务的并发操作,当 T1 读取 A 并准备修改时, T2 也读取了 A ,这样 T1 T2 读取的都是 30 ,当 T1 在第四步将修改后的结果写回数据库, T2 接着在第 6 步也将它的修改结果写回数据库中,这样就将 T1 的修改结果给覆盖了。
4. 解决办法——加锁
在事务要对数据库进行操作前,禁止其他事务再对该数据进行操作。
执行顺序 T1
 Lock A
Read A
A=A+10
Write A
Unlock A
T2
Lock A
Read A
A=A-30
Write A
Unlock A
这样最后数据库中A的值就是10而不是0。
【注意】通过采用数据库的加锁机制便可避免由于事务并发而导致的错误,但是对事务加锁并不能解决所有的并发操作,也不是并发控制的唯一办法。
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值