最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

检查锁定SQLServer数据库的ProcessID

来源:动视网 责编:小采 时间:2020-11-09 16:08:58
文档

检查锁定SQLServer数据库的ProcessID

检查锁定SQLServer数据库的ProcessID:检查锁定SQLServer数据库的ProcessID 无 CREATE PROCEDURE #sp_who_lockASBEGINDECLARE @spid INTDECLARE @blk INTDECLARE @count INTDECLARE @index INTDECLARE @lock TINYINT 。SET @lock = 0 。D
推荐度:
导读检查锁定SQLServer数据库的ProcessID:检查锁定SQLServer数据库的ProcessID 无 CREATE PROCEDURE #sp_who_lockASBEGINDECLARE @spid INTDECLARE @blk INTDECLARE @count INTDECLARE @index INTDECLARE @lock TINYINT 。SET @lock = 0 。D


检查锁定SQLServer数据库的ProcessID 无 CREATE PROCEDURE #sp_who_lockASBEGINDECLARE @spid INTDECLARE @blk INTDECLARE @count INTDECLARE @index INTDECLARE @lock TINYINT ??SET @lock = 0 ??DECLARE @temp_who_lock AS TABLE (id INT identity(1, 1),sp

检查锁定SQL Server数据库的Process ID <无> $velocityCount-->
CREATE PROCEDURE #sp_who_lock
AS
BEGIN
	DECLARE @spid INT
	DECLARE @blk INT
	DECLARE @count INT
	DECLARE @index INT
	DECLARE @lock TINYINT ?
?
	SET @lock = 0 ?
?
	DECLARE @temp_who_lock AS TABLE (
	id INT identity(1, 1),
	spid INT,
	blk INT
	) ?
?
	IF @@error <> 0
	RETURN @@error ?
?
	INSERT INTO @temp_who_lock (
	spid,
	blk
	)
	SELECT 0,
	blocked
	FROM (
	SELECT *
	FROM master..sysprocesses
	WHERE blocked > 0
	) a
	WHERE NOT EXISTS (
	SELECT TOP 1 1
	FROM master..sysprocesses
	WHERE a.blocked = spid
	AND blocked > 0
	)
	UNION
	SELECT spid,
	blocked
	FROM master..sysprocesses
	WHERE blocked > 0 ?
?
	IF @@error <> 0
	RETURN @@error ?
?
	SELECT @count = count(1),
	@index = 1
	FROM @temp_who_lock ?
?
	IF @@error <> 0
	RETURN @@error ?
?
	IF @count = 0
	BEGIN
	SELECT N'没有阻塞和死锁信息' ?
?
	RETURN 0
	END ?
?
	WHILE @index <= @count
	BEGIN
	IF EXISTS (
	SELECT TOP 1 1
	FROM @temp_who_lock a
	WHERE id > @index
	AND EXISTS (
	SELECT TOP 1 1
	FROM @temp_who_lock
	WHERE id <= @index
	AND a.blk = spid
	)
	)
	BEGIN
	SET @lock = 1 ?
?
	SELECT @spid = spid,
	@blk = blk
	FROM @temp_who_lock
	WHERE id = @index ?
?
	SELECT N'引起数据库死锁的是:' + CAST(@spid AS NVARCHAR(10)) + N'进程号,其执行的SQL语法如下' ?
?
	SELECT @spid,
	@blk ?
?
	DBCC INPUTBUFFER (@spid) ?
?
	DBCC INPUTBUFFER (@blk)
	END ?
?
	SET @index = @index + 1
	END ?
?
	IF @lock = 0
	BEGIN
	SET @index = 1 ?
?
	WHILE @index <= @count
	BEGIN
	SELECT @spid = spid,
	@blk = blk
	FROM @temp_who_lock
	WHERE id = @index ?
?
	IF @spid = 0
	SELECT N'引起阻塞的是:' + CAST(@blk AS NVARCHAR(10)) + N'进程号,其执行的SQL语法如下'
	ELSE
	SELECT N'进程号SPID:' + CAST(@spid AS NVARCHAR(10)) + N'被进程号SPID:' + CAST(@blk AS NVARCHAR(10)) + N'阻塞,其当前进程执行的SQL语法如下' ?
?
	DBCC INPUTBUFFER (@spid) ?
?
	DBCC INPUTBUFFER (@blk) ?
?
	SET @index = @index + 1
	END
	END ?
?
	RETURN 0
END
GO
?
EXEC #sp_who_lock

文档

检查锁定SQLServer数据库的ProcessID

检查锁定SQLServer数据库的ProcessID:检查锁定SQLServer数据库的ProcessID 无 CREATE PROCEDURE #sp_who_lockASBEGINDECLARE @spid INTDECLARE @blk INTDECLARE @count INTDECLARE @index INTDECLARE @lock TINYINT 。SET @lock = 0 。D
推荐度:
标签: id 锁定 数据库
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top