Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Kennen Sie die Beziehungen zwischen allen Tabellen der Datenbank in SQL Server

Manchmal hilft auch eine Textdarstellung; Mit dieser Abfrage der Systemkatalogansichten erhalten Sie eine Liste aller FK-Beziehungen und wie die Verknüpfung zweier Tabellen erfolgt (und auf welchen Spalten sie operieren).

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

Geben Sie dies in Excel aus, und Sie können es aufteilen – basierend auf der übergeordneten Tabelle, der referenzierten Tabelle oder irgendetwas anderem.

Ich finde visuelle Anleitungen hilfreich - aber manchmal ist eine Textdokumentation genauso gut (oder sogar besser) - nur meine 2 Cent.....