sqlserver中查找所有包含了某個文本的存儲過程
更新時間:2010年05月27日 03:32:14 作者:
我想查找所有使用了sp_a 的存儲過程。右擊sp_a->view dependencies-> 選擇 view objects that depend on [sp_a] 你會發(fā)現,有時候結果不能夠全部列出來,不能夠找到所有使用了sp_a的其他存儲過程。
上圖說明吧。

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

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

結果有點雷人,居然沒有列出mup_GetB 來(我使用的是sql server 2005)
下面是解決方法
方法1:
打開數據庫管理界面->右擊數據庫->tasks->Generate Scripts->.....
導出所有存儲過程到文件中,然后ctrl+F查找
方法2:
SELECT ROUTINE_NAME, ROUTINE_DEFINITION
FROM INFORMATION_SCHEMA.ROUTINES
WHERE ROUTINE_DEFINITION LIKE '%text%'
AND ROUTINE_TYPE='PROCEDURE'
將text替換成你要查找的內容
方法3:
select name
from sysobjects o, syscomments s
where o.id = s.id
and text like '%text%'
and o.xtype = 'P'
將text替換成你要查找的內容
完畢

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

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

結果有點雷人,居然沒有列出mup_GetB 來(我使用的是sql server 2005)
下面是解決方法
方法1:
打開數據庫管理界面->右擊數據庫->tasks->Generate Scripts->.....
導出所有存儲過程到文件中,然后ctrl+F查找
方法2:
復制代碼 代碼如下:
SELECT ROUTINE_NAME, ROUTINE_DEFINITION
FROM INFORMATION_SCHEMA.ROUTINES
WHERE ROUTINE_DEFINITION LIKE '%text%'
AND ROUTINE_TYPE='PROCEDURE'
將text替換成你要查找的內容
方法3:
復制代碼 代碼如下:
select name
from sysobjects o, syscomments s
where o.id = s.id
and text like '%text%'
and o.xtype = 'P'
將text替換成你要查找的內容
完畢
相關文章
Microsoft SQL Server 2012 數據庫安裝圖解教程
這篇文章主要為大家介紹下Microsoft SQL Server 2012 數據庫安裝教程,需要的朋友可以參考下2013-11-11IN&EXISTS與NOT IN&NOT EXISTS 的優(yōu)化原則小結
下面只是從理論上提出了一些建議,最好的原則是大家在上面的基礎上,能夠使用執(zhí)行計劃來分析,得出最佳的語句的寫法。2010-06-06SQLServer中匯總功能的使用GROUPING,ROLLUP和CUBE
查看SQL Server的幫助才發(fā)現,厲害啊,原來還有這么厲害的東西,不由的想起以前做水晶報表的時候,原來在SQL Server中就可以實現這樣的功能.2010-07-07