数据库锁表原因分析
来源:互联网 发布:淘宝卖家发短信的软件 编辑:程序博客网 时间:2024/06/11 09:15
账户在清、结算流水插入中出现锁表
在联机事务处理(OLTP)的数据库应用系统中,多用户、多任务的并发性是系统最重要的技术指标之一。为了提高并发性,目前大部分RDBMS都采用加锁技术。然而由于现实环境的复杂性,使用加锁技术又不可避免地产生了死锁问题。因此如何合理有效地使用加锁技术,最小化死锁是开发联机事务处理系统的关键。
死锁产生的原因
在联机事务处理系统中,造成死机主要有两方面原因。一方面,由于多用户、多任务的并发性和事务的完整性要求,当多个事务处理对多个资源同时访问时,若双方已锁定一部分资源但也都需要对方已锁定的资源时,无法在有限的时间内完全获得所需的资源,就会处于无限的等待状态,从而造成其对资源需求的死锁。
另一方面,数据库本身加锁机制的实现方法不同,各数据库系统也会产生其特殊的死锁情况。如在Sybase SQL Server 11中,最小锁为2K一页的加锁方法,而非行级锁。如果某张表的记录数少且记录的长度较短(即记录密度高,如应用系统中的系统配置表或系统参数表就属于此类表),被访问的频率高,就容易在该页上产生死锁。
容易发生死锁的几种情况如下:
1>不同的存储过程、触发器、动态SQL语句段按照不同的顺序同时访问多张表;
2>在交换期间添加记录频繁的表,但在该表上使用了非群集索引(non-clustered);
3>表中的记录少,且单条记录较短,被访问的频率较高;
4>整张表被访问的频率高(如代码对照表的查询等)。
以上死锁情况的对应处理方法如下:
1>在系统实现时应规定所有存储过程、触发器、动态SQL语句段中,对多张表的操作总是使用同一顺序。如:有两个存储过程proc1、proc2,都需要访问三张表zltab、z2tab和z3tab,如果proc1按照zltab、z2tab和z3tab的顺序进行访问,那么,proc2也应该按照以上顺序访问这三张表。
2>对在交换期间添加记录频繁的表,使用群集索引(clustered),以减少多个用户添加记录到该表的最后一页上,在表尾产生热点,造成死锁。这类表多为往来账的流水表,其特点是在交换期间需要在表尾追加大量的记录,并且对已添加的记录不做或较少做删除操作。
3>对单张表中记录数不太多,且在交换期间select或updata较频繁的表可使用设置每页最大行的办法,减少数据在表中存放的密度,模拟行级锁,减少在该表上死锁情况的发生。这类表多为信息繁杂且记录条数少的表。
如:系统配置表或系统参数表。在定义该表时添加如下语句:
with max_rows_per_page=1
在存储过程、触发器、动态SQL语句段中,若对某些整张表select操作较频繁,则可能在该表上与其他访问该表的用户产生死锁。对于检查账号是否存在,但被检查的字段在检查期间不会被更新等非关键语句,可以采用在select命令中使用at isolation read uncommitted子句的方法解决。该方法实际上降低了select语句对整张表的锁级别,提高了其他用户对该表操作的并发性。在系统高负荷运行时,该方法的效果尤为显著。
如:
select * from titles at isolation read uncommitted
对流水号一类的顺序数生成器字段,可以先执行updata流水号字段+1,然后再执行select获取流水号的方法进行操作。
- 数据库锁表原因分析
- 数据库锁表原因分析
- 数据库锁表原因分析
- 数据库被锁原因分析
- 数据库运行慢原因分析
- 造成数据库表死锁的原因分析及解决方案
- 分析数据库死锁原因的方法
- 分析数据库死锁原因的方法
- 分析数据库死锁原因的方法
- 分析数据库死锁原因的方法
- 数据库死锁问题原因分析以及解决方案
- 数据库创建表失败原因
- mysql死锁-查询锁表进程-分析锁表原因
- mysql死锁-查询锁表进程-分析锁表原因
- 数据库锁表及阻塞的原因和解决办法
- (转帖)分析数据库死锁原因的方法
- 某RAC数据库一个节点“宕机”原因分析
- 分析2005及以上数据库变慢的原因
- Python集成开发环境(Eclipse + Pydev)
- UVALive 6533 Inverting Huffman 哈夫曼树(构造
- java编写的2048程序
- Java实现深、浅Clone
- 20141030 N2
- 数据库锁表原因分析
- 【引用】objective-c copy mutableCopy 拷贝对象
- 【引用】Objective-C 的 self 和 super 详解
- Objective-C学习笔记第一章启程
- Objective-C学习笔记第二章对C的扩展
- Objective-C学习笔记第三章面向对象编程
- Objective-C学习笔记第四章继承
- Objective-C学习笔记第五章复合
- Objective-C学习笔记第六章原文件组织