Query to find stored procedures by nested stored procedure name

Problem: Suppose we have a stored procedure which has been used in several stored procedure, I mean stored procedure usp_proc1 is nested in many stored procedures like below

    ID INT,
       NAME VARCHAR(50),
       [ADDRESS] VARCHAR(255)
  EXEC usp_proc1 @Name='codefari'

So I want to find all those queries containing usp_proc1
Solution: There is a lot of solutions, I'm giving some of them below.
If you want to get the only name of the stored procedures then use the following query. Using join query on system tables syscomments and sysobjects we can get the stored procedures name which containing the particular table, nested procs or any other string.

FROM syscomments s
INNER JOIN sysobjects o ON s.id=o.id
WHERE s.TEXT LIKE '%text for search%'

If you want to get stored procedures and its type then run the following query.

SELECT DISTINCT o.name, o.xtype
FROM syscomments c
INNER JOIN sysobjects o ON c.id=o.id
WHERE c.TEXT LIKE '%text for search%'

We can get the expected result using the following query also, in this query I used only sys.objects table to get the appropriate result. The following query will return sp_name, schema_name, type, and type_desc.

SELECT schema_name(o.schema_id) AS [schema_name],
  NAME AS sp_name
FROM sys.objects o
WHERE o.is_ms_shipped = 0
  AND OBJECT_DEFINITION(object_id) Like '%text for search%'
  AND type = 'p' ORDER BY o.NAME

We can get the appropriate result using table sysdepends and sysobjects see the following query. It will return all those records of stored procedures and their dependent stored procedures. If you want to apply a filter then un-comment the AND condition.

SELECT o.name sp_name, dpt.name nested_spname
 FROM sysdepends d
INNER JOIN sysobjects o on d.id = o.id
INNER JOIN sysobjects dpt on d.depid = dpt.id
WHERE o.xtype = 'P' AND dpt.xtype = 'P'
--AND dpt.name like '%text for search%'

Using system procedure sp_depends we can get the all expected records, see the following query.

EXEC sp_depends @objname = N'proc name';

Related Posts

Fatal Error: Peer authentication failed for user "postgres", when trying to get pgsql working with rails.

Problem: Sometimes, we get the following error when trying to make a connection in Rails.  FATAL ERROR: Peer authentication failed for us...