死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象。若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁。
产生死锁的四个必要条件:
1.互斥条件:一个资源每次只能被一个进程使用。
2.请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
3.不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
4.循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
一般情况下,很难改变前三个条件,因为这是锁本身具有的特性。在编程过程中,应该尽量避免循环等待,解决死锁问题的关键就是:让不同的session加锁有次序。例如:
在第一个session中:
begin
select * from A where id =9 for update
select * from B where id=10 for update
commit
在第二个session中:
begin
select * from B where id=10 for update
select * from A where id =9 for update
commit
执行的时候第一个session获得了id为9的行锁,第二个session获得了id为10的行锁。第一个session无法获得B表对应行,第二个session无法获得A表对应行,出现的循环等待的现象。调整执行select...for update 语句的执行顺序 可以消除死锁现象。