Consulta para listar todos os procedimentos armazenados


338

Qual consulta pode retornar os nomes de todos os procedimentos armazenados em um banco de dados do SQL Server

Se a consulta pudesse excluir procedimentos armazenados do sistema, isso seria ainda mais útil.

Respostas:


499

Como Mike afirmou, a melhor maneira é usar information_schema. Enquanto você não estiver no banco de dados mestre, os procedimentos armazenados do sistema não serão retornados.

SELECT * 
  FROM DatabaseName.INFORMATION_SCHEMA.ROUTINES
 WHERE ROUTINE_TYPE = 'PROCEDURE'

Se, por algum motivo, você tiver procedimentos armazenados fora do sistema no banco de dados mestre, poderá usar a consulta (isso filtrará a maioria dos procedimentos armazenados no sistema):

SELECT * 
  FROM [master].INFORMATION_SCHEMA.ROUTINES
 WHERE ROUTINE_TYPE = 'PROCEDURE' 
   AND LEFT(ROUTINE_NAME, 3) NOT IN ('sp_', 'xp_', 'ms_')

3
Se você criar diagramas de banco de dados, poderá obter vários procs começando com 'dt_' no seu banco de dados, que também podem ser filtrados.
John Fouhy

+1 para o esquema de informações. vale a pena ler: msdn.microsoft.com/en-us/library/ms186778.aspx
Shiham

Deve ser "Enquanto você não estiver nos bancos de dados [master] ou [msdb], ..."
Solomon Rutzky

107
SELECT name, 
       type
  FROM dbo.sysobjects
 WHERE (type = 'P')

4
Isso funcionou para mim em um ambiente compartilhado no MS-SQL 2008; os dois anteriores não ...
Realto619 25/11

3
Qualquer pessoa que use o SQL Server 2005 ou mais recente deve se afastar dos modos de dbo.sys*exibição. Essa consulta também: filtra os procedimentos armazenados do CLR, não filtra os procs armazenados do sistema e retorna [type] quando se sabe que [type] sempre será 'P', pois é a condição WHERE.
Solomon Rutzky

que não vai funcionar se os objetos no banco de dados tem esquema diferente
Foyzul Karim

30

Pelo meu entendimento, o método "preferido" é usar as tabelas information_schema:

select * 
  from information_schema.routines 
 where routine_type = 'PROCEDURE'

os registros retornados não parecem ter uma maneira de diferenciar os procedimentos armazenados do sistema

18

O seguinte retornará todos os procedimentos no banco de dados selecionado

SELECT * FROM sys.procedures

Isso tem modificado e data de criação, etc. que é muito útil
ihightower

14

Você pode tentar esta consulta para obter procedimentos e funções armazenados:

SELECT name, type
FROM dbo.sysobjects
WHERE type IN (
    'P', -- stored procedures
    'FN', -- scalar functions 
    'IF', -- inline table-valued functions
    'TF' -- table-valued functions
)
ORDER BY type, name

10

Se você estiver usando o SQL Server 2005, o seguinte funcionará:

select *
  from sys.procedures
 where is_ms_shipped = 0

isso vai dar o resultado errado e incluem sistema como o diagrama de procedimento armazenado (sp_upgraddiagrams) no SQL Server 2008
HaveNoDisplayName

@Piyush É verdade que ele retornará os procs do diagrama, mas alguém pode não considerá-los como procs do "sistema", pois eles não vieram com a instalação padrão. O OP não especificou como lidar com isso, para não filtrá-los não é necessariamente errado.
Solomon Rutzky

@srutzky: - mas ainda não são sp's criados pelo usuário
HaveNoDisplayName

@Piyush True, mas como eu disse, o OP não especificou como lidar com procs que não são "criados pelo usuário" nem "sistema". E ninguém perguntou.
Solomon Rutzky

Ótima resposta. Obrigado por incluir "is_ms_shipped = 0."
Hans Vonn

8

Você pode usar uma das consultas abaixo para encontrar a lista de Procedimentos armazenados em um banco de dados:

Consulta1:

    SELECT 
        *
    FROM sys.procedures;

Consulta2:

    SELECT 
        * 
    FROM information_schema.routines 
    WHERE ROUTINE_TYPE = 'PROCEDURE' 

Se você deseja encontrar a lista de todos os SPs em todos os bancos de dados, use a consulta abaixo:

    CREATE TABLE #ListOfSPs 
    (
        DBName varchar(100), 
        [OBJECT_ID] INT,
        SPName varchar(100)
    )

    EXEC sp_msforeachdb 'USE [?]; INSERT INTO #ListOfSPs Select ''?'', Object_Id, Name FROM sys.procedures'

    SELECT 
        * 
    FROM #ListOfSPs

11
OMI seu exemplo usando o sp_msforeachdb é ouro e deve ser a resposta. Aqui está um link que eu encontrei de falar mais sobre este sproc: weblogs.sqlteam.com/joew/archive/2008/08/27/60700.aspx
Mike Cheel

8

Selecionar todos os procedimentos e exibições armazenados

select name,type,type_desc
from sys.objects
where type in ('V','P')
order by name,type

5

Isso também pode ajudar a listar o procedimento, exceto os procedimentos do sistema:

select * from sys.all_objects where type='p' and is_ms_shipped=0

Não há motivo para usar, sys.all_objectspois você está filtrando is_ms_shipped=0. Pode conter gatilhos DDL, mas esses seriam filtrados por type='p'. Você também pode usar sys.objects.
Solomon Rutzky

4

Infelizmente INFORMATION_SCHEMAnão contém informações sobre os procs do sistema.

SELECT *
  FROM sys.objects
 WHERE objectproperty(object_id, N'IsMSShipped') = 0
   AND objectproperty(object_id, N'IsProcedure') = 1

11
Por que você usaria isso em vez de sys.procedures where is_ms_shipped = 0? E por que você executaria uma função objectproperty(object_id, N'IsMSShipped')para cada linha quando há um campo is_ms_shippedque contém esse valor? Na mesma linha, por que executar essa função novamente quando [type] IN ('P', 'PC')faz a mesma coisa? Este método é desnecessariamente complicado e ineficiente.
Solomon Rutzky

4

Apenas os nomes:

SELECT SPECIFIC_NAME  
FROM YOUR_DB_NAME.information_schema.routines  
WHERE routine_type = 'PROCEDURE'

3

Alterei a excelente postagem de LostCajun acima para excluir os procedimentos armazenados do sistema. Também removi "Extrair". do código porque eu não conseguia descobrir para que serve e isso me deu erros. A instrução "buscar próximo" dentro do loop também precisava de uma cláusula "into".

use <<databasename>>
go

declare @aQuery nvarchar(1024);
declare @spName nvarchar(64);
declare allSP cursor for
    select p.name  
    from sys.procedures p 
    where p.type_desc = 'SQL_STORED_PROCEDURE' 
    and LEFT(p.name,3) NOT IN ('sp_','xp_','ms_')
    order by p.name;
open allSP;
fetch next from allSP into @spName;
while (@@FETCH_STATUS = 0)
begin
    set @aQuery = 'sp_helptext [' + @spName + ']';
    exec sp_executesql @aQuery;
    fetch next from allSP into @spName;
end;
close allSP;
deallocate allSP;

2

a melhor maneira de obter objetos é usar sys.sql_modules. você pode encontrar tudo o que deseja dessa tabela e associá-la a outra tabela para obter mais informações por object_id

SELECT o. object_id,o.name AS name,o.type_desc,m.definition,schemas.name scheamaName
FROM sys.sql_modules        m 
    INNER JOIN sys.objects  o ON m.object_id=o.OBJECT_ID
    INNER JOIN sys.schemas ON schemas.schema_id = o.schema_id
    WHERE [TYPE]='p'

1
select *  
  from dbo.sysobjects
 where xtype = 'P'
   and status > 0

status> 0 não parece diferenciar entre procedimentos e armazenados do sistema aqueles criados

Hmm. Faz para nós - não sei por que.
Bob Probst

Qualquer pessoa que use o SQL Server 2005 ou mais recente deve se afastar dos modos de dbo.sys*exibição. Essa consulta também filtra os procedimentos armazenados do CLR.
Solomon Rutzky

1

Eu escrevi este tsql simples para listar o texto de todos os procedimentos armazenados. Certifique-se de substituir o nome do banco de dados no campo

use << database name >>
go

declare @aQuery nvarchar(1024);
declare @spName nvarchar(64);
declare allSP cursor for
select p.name  from sys.procedures p where p.type_desc = 'SQL_STORED_PROCEDURE' order by p.name;
open allSP;
fetch next from allSP into @spName;
while (@@FETCH_STATUS = 0)
begin
    set @aQuery = 'sp_helptext [Extract.' + @spName + ']';
    exec sp_executesql @aQuery;
    fetch next from allSP;
end;
close allSP;
deallocate allSP;

consulte a reescrita de @BaffledBill disso .. que funcionou para mim. Este não funcionou, pois havia muitos erros.
Ihightower 19/04

1

Isso fornecerá apenas os nomes dos procedimentos armazenados.

select specific_name
from information_schema.routines
where routine_type = 'PROCEDURE';

1

Isso mostrará todos os procedimentos armazenados e o código:

select sch.name As [Schema], obj.name AS [Stored Procedure], code.definition AS [Code] from sys.objects as obj
    join sys.sql_modules as code on code.object_id = obj.object_id
    join sys.schemas as sch on sch.schema_id = obj.schema_id
    where obj.type = 'P'

0

Isto, liste todas as coisas que você deseja

No Sql Server 2005, 2008, 2012:

Use [YourDataBase]

EXEC sp_tables @table_type = "'PROCEDURE'" 
EXEC sp_tables @table_type = "'TABLE'"
EXEC sp_tables @table_type = "'VIEW'" 

OU

SELECT * FROM information_schema.tables
SELECT * FROM information_schema.VIEWS

Não há razão para usar ou se beneficiar do uso sp_tables,. Além disso, "PROCEDURE" não é uma opção válida para sp_tables. As únicas opções para @table_typesão: 'SYSTEM TABLE', 'TABLE' e 'VIEW'.
Solomon Rutzky

0

Isso retornará todos os nomes sp

Select * 
FROM sys.procedures where [type] = 'P' 
     AND is_ms_shipped = 0 
     AND [name] not like 'sp[_]%diagram%'

A condição ativada [type]deve ser [type] IN ('P', 'PC')outra coisa: você está filtrando todos os procs armazenados do CLR que estão potencialmente lá.
Solomon Rutzky


0
select * from DatabaseName.INFORMATION_SCHEMA.ROUTINES where routine_type = 'PROCEDURE'

select * from DatabaseName.INFORMATION_SCHEMA.ROUTINES where routine_type ='procedure' and left(ROUTINE_NAME,3) not in('sp_', 'xp_', 'ms_')


   SELECT name, type   FROM dbo.sysobjects
 WHERE (type = 'P')

0
USE DBNAME

select ROUTINE_NAME from information_schema.routines 
where routine_type = 'PROCEDURE'


GO 

Isso funcionará no mssql.


Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.