Applies To: SQL Server 2014, SQL Server 2016 Preview
Topic Status: Some information in this topic is preview and subject to change in future releases. Preview information describes new features or changes to existing features in Microsoft SQL Server 2016 Community Technology Preview 2 (CTP2).
Returns the indexed column name. Returns NULL for XML indexes.
Applies to: SQL Server (SQL Server 2008 through current version), Azure SQL Database.
Returns NULL on error or if a caller does not have permission to view the object.
A user can only view the metadata of securables that the user owns or on which the user has been granted permission. This means that metadata-emitting, built-in functions such as INDEX_COL may return NULL if the user does not have any permission on the object. For more information, see Metadata Visibility Configuration.
A. Using INDEX_COL to return an index column name
The following example returns the column names of the two key columns in the index PK_SalesOrderDetail_SalesOrderID_LineNumber.
USE AdventureWorks2012; GO SELECT INDEX_COL (N'AdventureWorks2012.Sales.SalesOrderDetail', 1,1) AS [Index Column 1], INDEX_COL (N'AdventureWorks2012.Sales.SalesOrderDetail', 1,2) AS [Index Column 2] ; GO
Here is the result set:
Index Column 1 Index Column 2 ----------------------------------------------- SalesOrderID SalesOrderDetailID