避免死锁

因为打开的事务可能会死锁资源,引发性能的问题,所以了解在一个专用数据库中哪些事务是打开的是很有帮助的。被死锁的资源可能堵塞其他数据库的用户。
advertisement_e1.gif
banner.gif banner.gif code;sz=1x1;ord=6992489?

为了找出这些已打开的事务就要查询master数据库中的sysprocesses表。sysprocesses表有一个open_tran的列,它表示已有命令是否是一个打开的事务。如果值大于0表示它是一个已经打开的事务。sysprocesses表还有一个spid的列,表示正在访问SQL Server的系统进程的id。你可以使用spid列作为DBCC INPUTBUFFER()系统函数的参数。只有SQL Server的sysadmins帐号才可以执行这个函数。这个函数的输出首先是spid对应的255字符的命令。你可以由此确定哪个命令是影响数据库性能的罪魁祸首,然后根据spid发出一个KILL命令。

下面是打印已打开事务的命令的脚本。它用到了表变量,因此只能在SQL Server 2000上用。

SET NOCOUNT ON
DECLARE @Commands
      TABLE
      ( ctr INT IDENTITY NOT NULL,
      command VARCHAR(2000) NOT NULL)

INSERT @Commands (command)
SELECT 'DBCC INPUTBUFFER (' + CONVERT( VARCHAR(10), spid) + ')'
FROM master..sysprocesses
WHERE open_tran > 0

DECLARE @ctr INT, @command VARCHAR(2000)
SET @ctr = 1

WHILE @ctr < (SELECT COUNT(*) + 1 FROM @Commands)
BEGIN
      SELECT @command = command FROM @Commands WHERE ctr = @ctr
      PRINT '-- ' + @command
      EXECUTE (@command)
      SELECT @ctr = @ctr + 1
END

转载于:https://www.cnblogs.com/RayCheung/archive/2006/03/21/354534.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值