事务并发——并发控制(加锁)
来源:互联网 发布:驾考科二模拟软件下载 编辑:程序博客网 时间:2024/04/19 19:57
事务处理中的并发控制:
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。
【注意】通过采用数据库的加锁机制便可避免由于事务并发而导致的错误,但是对事务加锁并不能解决所有的并发操作,也不是并发控制的唯一办法。
- 事务并发——并发控制(加锁)
- 数据库—事务—并发控制技术
- 串行等价化 事务 并发 加锁 死锁
- 事务与并发控制
- 事务与并发控制
- 事务的并发控制
- 数据库 事务并发控制
- 事务的并发控制
- 事务并发控制
- 并发控制与事务
- 事务-----并发控制
- SQL server数据库并发控制--加锁
- MySQL的并发控制与加锁分析
- MySQL的并发控制与加锁分析
- mysql的并发控制和加锁分析
- MySQL的并发控制和加锁分析
- 事务——恢复和并发控制的基本单位
- 数据库并发控制几只——事务
- ASP调用带参数存储过程的几种方式
- div+css实现Firefox和IE6兼容的垂直居中
- 他们的军训
- div+css的margin缩写方式
- 工作流应用系统水平解决方案设计思路探索
- 事务并发——并发控制(加锁)
- 去除乱码
- Microsoft SoftGrid 概述
- 解析#pragma指令
- div+css的格式较验
- 雅虎10,000,000 USD正式收购Mybloglog
- sizeof()与strlen()用法
- 思考 将来做什么?!
- 在Window下编译OpenH323(上)---------编译PWLib