Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Lista wszystkich indeksów i kolumn indeksów w bazie danych SQL Server

Istnieją dwa widoki katalogu „sys”, z którymi możesz się zapoznać:sys.indexes i sys.index_columns .

Dają one prawie wszystkie informacje o indeksach i ich kolumnach, których możesz potrzebować.

EDYCJA:To zapytanie zbliża się do tego, czego szukasz:

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. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak przekazać wartość do parametru procedury składowanej w składniku źródłowym OLE DB?

  2. Domyślna kolejność wierszy w zapytaniu SELECT — SQL Server 2008 vs SQL 2012

  3. Połącz PHP z MSSQL przez PDO ODBC

  4. Kopia zapasowa na poziomie tabeli

  5. Konwersja typu danych datetime2 na typ danych datetime wynika z wartości spoza zakresu