码迷,mamicode.com
首页 > 数据库 > 详细

SQL死锁

时间:2014-08-19 18:53:35      阅读:276      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   使用   io   数据   ar   div   

我们操作数据库大量数据时,可能会出现死锁现象。

所谓死锁: 是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。 由于资源占用是互斥的,当某个进程提出申请资源后,使得有关进程在无外力协助下,永远分配不到必需的资源而无法继续运行,这就产生了一种特殊现象:死锁。

死锁的四个必要条件 

通常都会介绍死锁的四个必要条件。这四个条件缺一不可,或者说只要破坏了其中任何一个条件,死锁就不可能发生。我们来复习一下,这四个条件是:
•互斥(Mutual exclusion):存在这样一种资源,它在某个时刻只能被分配给一个执行绪(也称为线程)使用;
•持有(Hold and wait):当请求的资源已被占用从而导致执行绪阻塞时,资源占用者不但无需释放该资源,而且还可以继续请求更多资源;
•不可剥夺(No preemption):执行绪获得到的互斥资源不可被强行剥夺,换句话说,只有资源占用者自己才能释放资源;
•环形等待(Circular wait):若干执行绪以不同的次序获取互斥资源,从而形成环形等待的局面,想象在由多个执行绪组成的环形链中,每个执行绪都在等待下一个执行绪释放它持有的资源。

检测是否有死锁:

USE [master]
GO

DECLARE    @return_value int

EXEC    @return_value = [dbo].[auto_checkblocks]

SELECT    Return Value = @return_value

GO

如果有死锁Return Value的是不是0

直接在sql中执行 Kill ‘Return Value 非0的值’ ,就OK了。

 

SQL死锁,布布扣,bubuko.com

SQL死锁

标签:style   blog   color   使用   io   数据   ar   div   

原文地址:http://www.cnblogs.com/bit-by-bit/p/3922706.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!