get the text of a stored procedure into a variable in SQL Server

旧城冷巷雨未停 提交于 2019-12-01 17:23:35

The portable way is to use the ANSI/ISO view INFORMATION_SCHEMA.ROUTINES, but you'll only get the first 4000 characters of the stored procedure definition:

declare @source_code varchar(max)

select @source_code = t.ROUTINE_DEFINITION
from information_schema.routines t
where specific_schema = 'owner-schema'             -- e.g., dbo
  and specific_name   = 'my_stored_procedure_name' -- your stored procedure name here

Or you can use the system view sys.sql_modules in the same vein:

declare @source_code varchar(max)

select @source_code = definition
from sys.sql_modules
where object_id = object_id('dbo.my_stored_procedure_name')

Or, the simplest way:

declare @source_code varchar(max)
set @source_code = object_definition( 'dbo.my_stored_procedure_name' )
Virendra yadav

Nicholas Carey's third option needs some changes,

object_definition function needs object_id as parameter,

so the code should be

declare @source_code varchar(max)
declare @objectid int
select @objectid=object_id('dbo.my_stored_procedure_name')
select @source_code = object_definition(@objectid )

Check to this link more details https://msdn.microsoft.com/en-IN/library/ms176090.aspx

You can use the system stored procedure sp_helptext to get the stored procedure definition into a table and then just query against that temp table / table variable something like this..

DECLARE @TABLE TABLE
(Line_Number INT IDENTITY(1,1), Text_Column NVARCHAR(MAX));

INSERT INTO @TABLE(Text_Column)
EXECUTE sp_helptext Your_Proc_Name

SELECT * 
FROM @TABLE
WHERE Text_Column LIKE '%BOCTEST%'

UPDATE

SELECT p.name
      ,m.[definition]
FROM  sys.procedures p 
INNER JOIN sys.sql_modules m
ON    P.[object_id] = m.[object_id]
WHERE m.[definition] LIKE '%BOCTEST%'
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!