首页 > 数据库技术 > 详细

sql server 查询所有被锁表并批量解除

时间:2019-02-15 20:51:13      阅读:522      评论:0      收藏:0      [点我收藏+]

废话不多说,直接上代码:

--查询被锁表
select   request_session_id   spid,OBJECT_NAME(resource_associated_entity_id) tableName   
from   sys.dm_tran_locks where resource_type=‘OBJECT‘

	declare @spid  int 
	--循环所有实验室数据
	DECLARE Spid_Cursor CURSOR --定义游标
	FOR (select request_session_id spid
from sys.dm_tran_locks where resource_type=‘OBJECT‘ ) --查询出被锁表spid
	OPEN Spid_Cursor; --打开游标
	FETCH NEXT FROM Spid_Cursor INTO @spid; --读取第一行数据
	WHILE @@FETCH_STATUS = 0
		BEGIN	
declare @sql varchar(1000)
set @sql=‘kill ‘+cast(@spid  as varchar)
exec(@sql)

			FETCH NEXT FROM Spid_Cursor INTO @spid; --读取下一行数据
		END
	CLOSE Spid_Cursor; --关闭游标
	DEALLOCATE Spid_Cursor; --释放游标	

  

sql server 查询所有被锁表并批量解除

原文:https://www.cnblogs.com/wanggang2016/p/10385659.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!