sql >> Base de Datos >  >> RDS >> Sqlserver

Lista de tablas utilizadas en todos los procedimientos almacenados con el nombre de esquema de SP

Pruebe esta consulta:

SELECT * 
FROM INFORMATION_SCHEMA.ROUTINES

Esto devolverá todos los procedimientos almacenados en la base de datos actual y también el esquema asociado.

Si desea obtener las tablas y el procedimiento almacenado relacionado, intente algo como esto:

SELECT t.TABLE_NAME, s.ROUTINE_NAME,s.SPECIFIC_SCHEMA
FROM INFORMATION_SCHEMA.TABLES t
INNER JOIN INFORMATION_SCHEMA.ROUTINES s 
ON s.ROUTINE_NAME IN 
(
        SELECT referencing_entity_name 
        FROM sys.dm_sql_referencing_entities(TABLE_SCHEMA + '.' + TABLE_NAME, 'OBJECT')
)
AND s.ROUTINE_TYPE = 'PROCEDURE'
WHERE t.TABLE_TYPE = 'BASE TABLE'

Manténgase alejado de las vistas de sysobject, etc.