相信我们在进行测试的时候,有的时候会遇上数据库表的值插不进去的情况,在执行SQL语句的时候,好像卡住一样,没有反应。但是当你把SQL语句copy下来放在PL/SQL中执行的时候,在语法没有任何的错误,但是执行会很慢,此时我们就应该要想到应该表被锁了,尤其是当多条语句不停的提交,不停的执行的时候,这个时候就会由于语句执行不完整,而容易引起锁表。
下面先介绍一下表的锁已经在设计是应该注意的问题。
在数据库中有两种基本的锁类型:排它锁(Exclusive Locks,即X锁)和共享锁(Share Locks,即S锁)。当数据对象被加上排它锁时,其他的事务不能对它读取和修改。加了共享锁的数据对象可以被其他事务读取,但不能修改。数据库利用这两种基本的锁类型来对数据库的事务进行并发控制。
死锁的第一种情况: