Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Conoscere le relazioni tra tutte le tabelle del database in SQL Server

A volte, anche una rappresentazione testuale potrebbe aiutare; con questa query sulle viste del catalogo di sistema, puoi ottenere un elenco di tutte le relazioni FK e come collegano due tabelle (e su quali colonne operano).

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

Scaricalo in Excel e puoi affettare e tagliare a cubetti, in base alla tabella principale, alla tabella di riferimento o qualsiasi altra cosa.

Trovo utili le guide visive, ma a volte la documentazione testuale è altrettanto buona (o anche migliore) - solo i miei 2 centesimi.....