ITPUB??ì3
ITPUB论坛 » Rational » SQL死锁如何解决

标题: SQL死锁如何解决
离线 juanpeng
中级会员



精华贴数 0
个人空间 0
技术积分 4608 (294)
社区积分 0 (1441085)
注册日期 2007-6-21
论坛徽章:27
开发板块每日发贴之星开发板块每日发贴之星开发板块每日发贴之星生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠
生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠

发表于 2008-7-5 22:19 
SQL死锁如何解决

SQL死锁如何解决
最近我们公司的clearquest在进行操作的时候经常出现无响应的时候
然后发现原数据库因是由于SQL2000死锁造成的
目前我们公司的环境是 clearquest  2002.05.00
                                          SQL2000数据库
                     用户大概有100人左右
                     
在网上查找了一些方法 都没有奏效
不知道大家有没有遇到过此类问题 后来是如何解决的


只看该作者    顶部
离线 dotnetworker
一般会员



精华贴数 0
个人空间 0
技术积分 4616 (293)
社区积分 0 (1442073)
注册日期 2007-6-21
论坛徽章:33
开发板块每日发贴之星开发板块每日发贴之星开发板块每日发贴之星生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠
生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠生肖徽章2007版:鼠

发表于 2008-7-5 22:20 
引用:
原帖由 ljs53 于 2008-7-5 13:21 发表
最近我们公司的clearquest在进行操作的时候经常出现无响应的时候
然后发现原数据库因是由于SQL2000死锁造成的
目前我们公司的环境是 clearquest  2002.05.00
                                          SQL2000 ... 曾经关注过这个问题,下面是我再网上找到的方法,可以参考这个自己写个脚本用于检测是否有死锁!如果存在死锁就杀掉,当然这是防御措施,最好还是要从根源处解决问题,你可以看看自己的cq hook是否有问题,sp4是否已经更新,并发处理是否有问题等!复制内容到剪贴板代码:
use master --必须在master数据库中创建
go

if exists (select * from dbo.sysobjects where id = object_id(n[dbo].[p_lockinfo]) and objectproperty(id, nisprocedure) = 1)
drop procedure [dbo].[p_lockinfo]
go

/*--处理死锁

查看当前进程,或死锁进程,并能自动杀掉死进程

因为是针对死的,所以假如有死锁进程,只能查看死锁进程
当然,您能够通过参数控制,不管有没有死锁,都只查看死锁进程

感谢: caiyunxia,jiangopen 两位提供的参考信息

--邹建 2004.4--*/

/*--调用示例

exec p_lockinfo
--*/
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 master..sysprocesses a join (
  select blocked from master..sysprocesses 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 master..sysprocesses 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 master..sysprocesses
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<=@count
  begin
   select @spid=进程id,@标志=标志 from #t where id=@i
   insert #t1 exec(dbcc inputbuffer(+@spid+))
   if @标志=死锁的进程 exec(kill +@spid)
   set @i=@i+1
  end
end
else
  while @i<=@count
  begin
   select @s=dbcc inputbuffer(+cast(进程id as varchar)+) from #t where id=@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
go


只看该作者    顶部
 
    

相关内容


CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号 联系我们 法律顾问