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

Conozca las relaciones entre todas las tablas de la base de datos en SQL Server

A veces, una representación textual también puede ayudar; con esta consulta en las vistas del catálogo del sistema, puede obtener una lista de todas las relaciones FK y cómo vinculan dos tablas (y en qué columnas operan).

SELECT
    fk.name 'FK Name',
    tp.name 'Parent table',
    cp.name, cp.column_id,
    tr.name 'Refrenced table',
    cr.name, cr.column_id
FROM 
    sys.foreign_keys fk
INNER JOIN 
    sys.tables tp ON fk.parent_object_id = tp.object_id
INNER JOIN 
    sys.tables tr ON fk.referenced_object_id = tr.object_id
INNER JOIN 
    sys.foreign_key_columns fkc ON fkc.constraint_object_id = fk.object_id
INNER JOIN 
    sys.columns cp ON fkc.parent_column_id = cp.column_id AND fkc.parent_object_id = cp.object_id
INNER JOIN 
    sys.columns cr ON fkc.referenced_column_id = cr.column_id AND fkc.referenced_object_id = cr.object_id
ORDER BY
    tp.name, cp.column_id

Vuelque esto en Excel y podrá rebanarlo y dividirlo, según la tabla principal, la tabla a la que se hace referencia o cualquier otra cosa.

Encuentro útiles las guías visuales, pero a veces, la documentación textual es igual de buena (o incluso mejor), solo mis 2 centavos...