前言:
数据库和操作系统一样,都是一个多用户的共享资源。所以也会发生死锁,下面就分析一下死锁发生的原因,以及解决办法。
锁见解
在数据库中有两种基本的锁类型,排它锁(即X锁)和共享锁(即S锁)。当数据对象被加上排它锁时,其他的事务不能对它读取和修改。加了共享锁的数据对象可以被其他事务读取,但不能被修改。数据就是利用这两种锁型来对数据库的事务进行并发控制。
死锁第一种情况
一个用户A访问表A(锁住了A)然后又访问表B;另一个用户B访问表B(锁住了表B),然后企图访问表A;这时用户A由于用户B已经锁住表B,他必须等待用户B释放表B才能继续,同样用户B要等用户A释放表A才能才能继续,这就产生了死锁。
解决:
这种情况的锁比较常见、是由于程序的BUG产生的,除了调整程序的逻辑没有其他的方法。仔细分析程序的逻辑,对于数据库的多表操作时,尽量按照相同的顺序进 行处理,尽量避免同时锁定两个资源,如操作A和B两张表时,总是按先A后B的顺序处理, 必须同时锁定两个资源时,要保证在任何时刻都应该按照相同的顺序来锁定资源。
死锁产生的第二种情况
用户A查询一条记录,然后修改该条记录;这时用户B修改该条记录,这时用户A的事务里锁的性质由查询的共享锁企图上升到独占锁,而用户B里的独占锁由于A有共享锁存在所以必须等A释放掉共享锁,而A由于B的独占锁而无法上升的独占锁也就不可能释放共享锁,于是出现了死锁。这种死锁比较隐蔽,但在稍大点的项 目中经常发生