如何快速查找使用了某个字段的所有存储过程
2015-01-21 · 知道合伙人数码行家
知道合伙人数码行家
向TA提问 私信TA
当一个系统中使用了很多的表,并且存在大量的存储过程,当数据库中的某个表删除了某个字段,那么相应的存储过程也需要改动,但是我们不知道哪些存储过程使用了该字段,那我们该怎么办?我们可以从之前的文档一个一个查找使用了该字段的存储过程,但是这样效率很多,而且还容易出错,我们可以使用下面的方法来查找所有使用了某个字段的存储过程。如下的函数:
[sql] view plaincopyprint?
01.GO
02.SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容
03.FROM syscomments sc
04.INNER JOIN sysobjects obj ON sc.Id = obj.ID
05.WHERE sc.TEXT LIKE '%' + '字段名' + '%'
06.AND TYPE = 'P'
07.GO
GO
SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容
FROM syscomments sc
INNER JOIN sysobjects obj ON sc.Id = obj.ID
WHERE sc.TEXT LIKE '%' + '字段名' + '%'
AND TYPE = 'P'
GO
下面举一个例子,比如查找数据库中所有使用了AdId这个字段的所有存储过程。
[sql] view plaincopyprint?
01.USE KyCms
02.GO
03.SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容
04.FROM syscomments sc
05.INNER JOIN sysobjects obj ON sc.Id = obj.ID
06.WHERE sc.TEXT LIKE '%' + 'AdID' + '%'
07.AND TYPE = 'P'
08.GO
USE KyCms
GO
SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容
FROM syscomments sc
INNER JOIN sysobjects obj ON sc.Id = obj.ID
WHERE sc.TEXT LIKE '%' + 'AdID' + '%'
AND TYPE = 'P'
GO
SELECT TOP 100 db_name(d.database_id) as DBName,s.name as 存储名称,s.type_desc as 存储类型,d.cached_time as SP添加到缓存的时间,
d.last_execution_time as 上次执行SP的时间,d.last_elapsed_time as [上次执行SP所用的时间(微妙)],d.total_elapsed_time as [完成此SP的执行所用的总时间(微妙)],
d.total_elapsed_time/d.execution_count as [平均执行时间(微妙)],d.execution_count as 自上次编译以来所执行的次数
FROM SYS.procedures S JOIN SYS.dm_exec_procedure_stats D
ON S.object_id=D.object_id
WHERE S.NAME='SP_Name'
ORDER BY D.total_elapsed_time/D.execution_count DESC