sql >> Database >  >> RDS >> Sqlserver

Lijst met alle index- en indexkolommen in SQL Server DB

Er zijn twee "sys"-catalogusweergaven die u kunt raadplegen:sys.indexes en sys.index_columns .

Die geven je zo ongeveer alle informatie die je maar wilt over indices en hun kolommen.

EDIT:deze zoekopdracht komt aardig in de buurt van wat je zoekt:

SELECT 
     TableName = t.name,
     IndexName = ind.name,
     IndexId = ind.index_id,
     ColumnId = ic.index_column_id,
     ColumnName = col.name,
     ind.*,
     ic.*,
     col.* 
FROM 
     sys.indexes ind 
INNER JOIN 
     sys.index_columns ic ON  ind.object_id = ic.object_id and ind.index_id = ic.index_id 
INNER JOIN 
     sys.columns col ON ic.object_id = col.object_id and ic.column_id = col.column_id 
INNER JOIN 
     sys.tables t ON ind.object_id = t.object_id 
WHERE 
     ind.is_primary_key = 0 
     AND ind.is_unique = 0 
     AND ind.is_unique_constraint = 0 
     AND t.is_ms_shipped = 0 
ORDER BY 
     t.name, ind.name, ind.index_id, ic.is_included_column, ic.key_ordinal;


  1. Slechte stand-by

  2. De parameterlimiet van 2100 bereiken (SQL Server) bij gebruik van Bevat()

  3. Een Accent Sensitive-zoekopdracht uitvoeren in MySql

  4. Oracle:een tabelkolom bijwerken met ROWNUM in combinatie met ORDER BY-clausule