sqlserver中查找所有包含了某個文本的存儲過程

我想查找所有使用了sp_a 的存儲過程。右擊sp_a-view dependencies- 選擇 view objects that depend on [sp_a] 你會發(fā)現(xiàn),有時候結(jié)果不能夠全部列出來,不能夠找到所有使用了sp_a的其他存儲過程。

上圖說明吧。

上圖存儲過程調(diào)用了mup_GetA(我把和項目相關(guān)的命名都擦除掉了)

上圖通過sqlserver 圖形管理器自帶的功能查看依賴于mup_GetA的對象。

結(jié)果有點雷人,居然沒有列出mup_GetB 來(我使用的是sql server 2005)

下面是解決方法
方法1:
打開數(shù)據(jù)庫管理界面->右擊數(shù)據(jù)庫->tasks->Generate Scripts->…..
導(dǎo)出所有存儲過程到文件中,然后ctrl+F查找
方法2:
代碼如下:
SELECT ROUTINE_NAME, ROUTINE_DEFINITION
FROM INFORMATION_SCHEMA.ROUTINES
WHERE ROUTINE_DEFINITION LIKE ‘%text%’
AND ROUTINE_TYPE=’PROCEDURE’

將text替換成你要查找的內(nèi)容

方法3:
代碼如下:
select name
from sysobjects o, syscomments s
where o.id = s.id
and text like ‘%text%’
and o.xtype = ‘P’

將text替換成你要查找的內(nèi)容

完畢

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點贊10 分享