加入收藏 | 设为首页 | Life家族 | SCMLife | RMLife | PMLife | SQALife | TESTLife | 企业VIP专区 | 中文化荣誉殿堂

查看完整版本: SQL死锁如何解决

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版本就可以了
具体原因不知道为什么
页: [1]
查看完整版本: SQL死锁如何解决