查询某个表被那些存储过程用到

本文介绍如何在 SQL Server 2008 中使用 T-SQL 查询特定表被哪些存储过程引用,以及如何查看和解锁被锁定的表。此外,还展示了查询所有存储过程的详细方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--sql2008 查询某个表被那些存储过程用到
select distinct object_name(id) from syscomments
where id in (select object_id from sys.objects where type ='P')
and  UPPER(text) like '%YN-C-1803%' order by object_name(id)
/*type char(2) 对象类型。可以是下列值之一:
C = CHECK 约束
D = 默认值或 DEFAULT 约束
F = FOREIGN KEY 约束
FN = 标量函数
IF = 内嵌表函数
K = PRIMARY KEY 或 UNIQUE 约束
L = 日志
P = 存储过程
R = 规则
RF = 复制筛选存储过程
S = 系统表
TF = 表函数
TR = 触发器
U = 用户表
V = 视图
X = 扩展存储过程*/

---查看锁表--spid 锁表进程--tableName 被锁表名
select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName from sys.dm_tran_locks where resource_type='OBJECT'


SELECT     [Spid] = session_Id, ecid, [Database] = DB_NAME(sp.dbid),
 [User] = nt_username, [Status] = er.status,
 [Wait] = wait_type,
 [Individual Query] = SUBSTRING(qt.text, er.statement_start_offset / 2, (CASE WHEN er.statement_end_offset = - 1 THEN LEN(CONVERT(NVARCHAR(MAX), qt.text))
                      * 2 ELSE er.statement_end_offset END - er.statement_start_offset) / 2),
                       [Parent Query] = qt.text,
                       Program = program_name, Hostname,
                       nt_domain, start_time
FROM    
     sys.dm_exec_requests er INNER JOIN  sys.sysprocesses sp ON er.session_id = sp.spid
     CROSS APPLY sys.dm_exec_sql_text(er.sql_handle) AS qt
WHERE     session_Id > 50 /* Ignore system spids.*/ AND session_Id NOT IN (@@SPID)
---解锁语句
 declare @spid int
 Set @spid = 136
 --锁表进程
 declare @sql varchar(1000)set
 @sql='kill '+cast(@spid as varchar)exec(@sql)


 --查询所有的存储过程
 select a.name,a.[type],b.[definition] from sys.all_objects a,sys.sql_modules b
where a.is_ms_shipped=0 and a.object_id = b.object_id and a.[type] in ('P')
order by a.[name] asc

转载于:https://www.cnblogs.com/imyzhou/p/10848929.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值