SQL Server死锁的解除方法

sqlserver 死锁

SQL Server死锁使我们经常遇到的问题,下面就为您介绍如何查询SQL Server死锁,希望对您学习SQL Server死锁方面能有所帮助。

    SQL Server死锁的查询方法:

    exec master.dbo.p_lockinfo 0,0 ---显示死锁的进程,不显示正常的进程

    exec master.dbo.p_lockinfo 1,0 ---杀死死锁的进程,不显示正常的进程

    SQL Server死锁的解除方法:

    Create proc p_lockinfo

    @kill_lock_spid bit=1, --是否杀掉死锁的进程,1 杀掉, 0 仅显示

    @show_spid_if_nolock bit=1 --如果没有死锁的进程,是否显示正常进程信息,1 显示,0 不显示

    as

    declare @count int,@s nvarchar(1000),@i int

    select id=identity(int,1,1),标志,

    进程ID=spid,线程ID=kpid,块进程ID=blocked,数据库ID=dbid,

    数据库名=db_name(dbid),用户ID=uid,用户名=loginame,累计CPU时间=cpu,

    登陆时间=login_time,打开事务数=open_tran, 进程状态=status,

    工作站名=hostname,应用程序名=program_name,工作站进程ID=hostprocess,​

域名=nt_domain,网卡地址=net_address

    into #t from(

    select 标志='死锁的进程',

    spid,kpid,a.blocked,dbid,uid,loginame,cpu,login_time,open_tran,

    status,hostname,program_name,hostprocess,nt_domain,net_address,

    s1=a.spid,s2=0

    from mastersysprocesses a join (

    select blocked from mastersysprocesses group by blocked

    )b on a.spid=b.blocked where a.blocked=0

    union all

    select '|_牺牲品_>',

    spid,kpid,blocked,dbid,uid,loginame,cpu,login_time,open_tran,

    status,hostname,program_name,hostprocess,nt_domain,net_address,

    s1=blocked,s2=1

    from mastersysprocesses a where blocked<>0

    )a order by s1,s2

    select @count=@@rowcount,@i=1

    if @count=0 and @show_spid_if_nolock=1

    begin

    insert #t

    select 标志='正常的进程',

    spid,kpid,blocked,dbid,db_name(dbid),uid,loginame,cpu,login_time,

    open_tran,status,hostname,program_name,hostprocess,nt_domain,net_address

    from mastersysprocesses

    set @count=@@rowcount

    end

    if @count>0

    begin

    create table #t1(id int identity(1,1),a nvarchar(30),b Int,EventInfo nvarchar(255))

    if @kill_lock_spid=1

    begin

    declare @spid varchar(10),@标志 varchar(10)

    while @i<<span>=@count

    begin

    select @spid=进程ID,@标志=标志 from #t whereid=@i

    insert #t1 exec('dbcc inputbuffer('+@spid+'

)')

    if @标志='死锁的进程' exec('kill'+@spid

    set @i=@i+1

    end

    end

    else

    while @i<<span>=@count

    begin

    select @s='dbcc inputbuffer('+cast(进程ID as varchar)+')' from #t whereid=@i

    insert #t1 exec(@s)

    set @i=@i+1

    end

    select a.*,进程的SQL语句=b.EventInfo

    from #t a join #t1 b on a.id=b.id

    end


相关推荐

  • 青岛速霸雕刻机厂技师解析雕刻机超程加工报警解除方法 【慧聪印刷网】在使用数控雕刻机加工工件时,如果操作不当或者是刀路设计不对,有时会出现加工超程报警,报警的出现说明雕刻机在运行过程中已达到了极限位位置。那么,当这种问题出现后应该如何解除报警呢?首先,超程时所有运动轴均被自动设置在点动状态,只
  • PDF文件安全性设置简单解除方法 网络上下载的pdf文件很多都带有安全性设置,通常的安全设置有:文档打印不允许、更改文档不允许、内容复制或提取不允许等等。在实际运用中,我们通常需要把PDF文件导出,保存为DOC文件(Word文件),并对其内容进行复制、修改等编辑操作;或者打
  • atitit.线程死锁 卡住无反应 的原因in cmd调用的解决方案  v3 q39 atitit.线程死锁卡住无反应的原因incmd调用的解决方案v3q391.问题::线程死锁卡住无反应11.1.分类::cmd调用,netio,fileio调用,multithread调用samevar的时候儿..11.2.原因readLi
  • 旋风除尘器的常见问题以及解决方法 旋风除尘器的常见问题以及解决方法根据多年来从事旋风除尘器的管理工作和现场调试经验,对旋风除尘器系统运行中出现的一系列问题提出新的思想和解决方法。并对旋风除尘器系统高效率运行进行了认真的分析,特别是对降低旋风除尘器的阻力后如何进行除尘效率提高
  • 手机QQ转账记录如何删除 QQ钱包交易记录删除方法详解 今天qq业务乐园小编为大家带来手机QQ转账记录如何删除,QQ钱包交易记录删除方法详解。手机QQ转账记录如今都会在QQ钱包中显示。如果你想要删除或清空QQ钱包里的交易记录,那就来看看本文带来的图文步骤吧,相信能够帮助到大家。QQ钱包交易记录删
  • 打印机删除不掉的解决方法 打印机删除不掉的解决方法在打印机故障的时候,有一种状态是总有一个文档留在打印机里删除不掉,使打印机程序也删除不掉,打印机也不能正常使用。解决方法:1,点击"开始"菜单里面的"运行",在"打开"的命令行里面输入:netstopspooler.
  • Outlook2003发件箱中的邮件无法删除的解决方法 折腾了一个下午,外加一个上午,我终于在今天12点以前搞定了!谢天谢地!解决方法:方法1:拨掉网线或者禁用网络连接,再打开Outlook2003,进入到发件箱中,应该可以删除了。这是要让Outlook处于离线状态,因为"正在发送的邮件是不能删
  • 卸载QQ时无法删除文件夹中Mfc42.dll、qdshm.dll 的解决方法 在卸载QQ时想删除安装目录,这个时候系统会提示无法删除Mfc42.dll、qdshm.dll文件,本文教你解决此问题的办法。首先介绍一下Mfc42.dll文件mfc42.dll是微软MicrosoftMFC程序库文件是一些程序运行所需的库文
  • win7 桌面IE快捷方式无法删除 解决方法 XP&VISTA&WIN7:桌面多处很多IE的快捷方式或者就是IE图标,右键属性执行IE后面跟WW.XXXX.COM流氓网址,或者右键属性里面只有创建快捷方式等。无论用360安全卫士亦或其他软件都无法彻底删除,重启后又会出现
  • 5种方法解除开机密码 电脑使用的17个绝招 5种方法解除开机密码电脑使用的17个绝招《电脑使用的17个绝招》1、关机、重启只要1秒钟如果你想让WindowsXP瞬间关机,那么可以按下CTRLALTDEL,接着在弹出的任务管理器中点击“关机”→“关机”,与此同时按住CTRL,不到1秒钟
  • 北京今晚解除红色预警 明日恢复五日制尾号限行   原标题:北京今晚24时解除空气重污染红色预警明日恢复五日制尾号限行  法制晚报讯(小编耿学清张婷)小编(牛讯ID:fzwb_52165216)刚刚从北京市空气重污染应急指挥部获悉,12月16日启动的空气重污染红色预警将于今晚24时解除,
  • 锐捷S3760交换机rgnos.bin文件被删除的解决方法 在一次网络设备调试培训中,一学生将锐捷S3760交换机的系统文件rgnos.bin误删除了,导致交换机进不了系统,本人经过长时间的摸索尝试和虚心求教,终于将问题解决。现将方法写明如下。第一,进入一台同型号同版本的设备中将rgnos.bin文

你的评论

就没有什么想说的吗?

最新博客

关于我们 加入传客 媒体报道 帮助中心 传客活动 免责声明 联系我们 移动版 移动应用

©2017传客网    琼ICP备15003173号-2    

本站部分文章来源于互联网,版权归属于原作者。
本站所有转载文章言论不代表本站观点,如是侵犯了原作者的权利请发邮件联系站长(weishubao@126.com),我们收到后立即删除。
站内所有资源仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您自己承担!

X