ljs53 2008-7-5 13:21
SQL死锁如何解决
最近我们公司的clearquest在进行操作的时候经常出现无响应的时候
然后发现原数据库因是由于SQL2000死锁造成的
目前我们公司的环境是 clearquest 2002.05.00
SQL2000数据库
用户大概有100人左右
在网上查找了一些方法 都没有奏效
不知道大家有没有遇到过此类问题 后来是如何解决的
听雨屋檐人 2008-7-5 16:17
[quote]原帖由 [i]ljs53[/i] 于 2008-7-5 13:21 发表 [url=http://www.scmlife.com/bbs/redirect.php?goto=findpost&pid=102371&ptid=13926][img]http://www.scmlife.com/bbs/images/common/back.gif[/img][/url]
最近我们公司的clearquest在进行操作的时候经常出现无响应的时候
然后发现原数据库因是由于SQL2000死锁造成的
目前我们公司的环境是 clearquest 2002.05.00
SQL2000 ... [/quote]
曾经关注过这个问题,下面是我再网上找到的方法,可以参考这个自己写个脚本用于检测是否有死锁!如果存在死锁就杀掉,当然这是防御措施,最好还是要从根源处解决问题,你可以看看自己的cq hook是否有问题,sp4是否已经更新,并发处理是否有问题等!
[code]
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[/code]
softfly 2008-7-5 21:44
我不是很清楚SS2K上是否有DEADLOCK MONITOR
但是我知道DB2上有
我建议你用同样的SCHEMA在DB2上建立一个USER DB
然后实用API来并发的POPUATE DATA
这样可以发现DEAD LOCK ISSUE
ljs53 2008-7-9 13:10
回复 沙发 的帖子
怎么查看并发处理有问题??
SP4是否有更新 是不是说SQL2000是否打上了SP4的补丁
ljs53 2008-7-9 13:12
现在出现问题的时候很多都是在modify状态下
向文本框写入内容的时候 就死锁了
ljs53 2008-8-6 08:35
现在终于解决了
把CQ的服务器端和所有用户的客户端都升级到7.0.1版本就可以了
具体原因不知道为什么