How to determine the primary key for a table in SQL Server?

后端 未结 8 2004
小蘑菇
小蘑菇 2020-12-16 07:13

What I\'d like to be able to do in SQL Server 2005 somehow is with a table name as input determine all the fields that make up the primary key. sp_columns doesn

8条回答
  •  死守一世寂寞
    2020-12-16 07:29

    I use this in a code generator I wrote to get the primary key:

    SELECT i.name AS IndexName, 
        OBJECT_NAME(ic.OBJECT_ID) AS TableName, 
        COL_NAME(ic.OBJECT_ID,ic.column_id) AS ColumnName, 
        c.is_identity, c.user_type_id, CAST(c.max_length AS int) AS max_length, 
        CAST(c.precision AS int) AS precision, CAST(c.scale AS int) AS scale 
    FROM sys.indexes AS i 
    INNER JOIN sys.index_columns AS ic 
    INNER JOIN sys.columns AS c ON ic.object_id = c.object_id AND ic.column_id = c.column_id 
        ON i.OBJECT_ID = ic.OBJECT_ID AND i.index_id = ic.index_id 
    WHERE i.is_primary_key = 1 AND ic.OBJECT_ID = OBJECT_ID('dbo.YourTableNameHere')
    ORDER BY OBJECT_NAME(ic.OBJECT_ID), ic.key_ordinal
    

提交回复
热议问题