SQL ServerでSQLを使用してプライマリーキー(PK)を取得する必要があったのでちょっと調査した結果をメモします。
プライマリーキー(PK)を取得する方法
SQL Serverでプライマリーキー(PK)を取得するSQLは以下の通りです。
SELECT
tbls.name AS table_name
,key_const.name AS constraint_name
,idx_cols.key_ordinal AS key_ordinal
,cols.name AS col_name
FROM
sys.tables AS tbls
INNER JOIN sys.key_constraints AS key_const ON
tbls.object_id = key_const.parent_object_id
AND key_const.type = 'PK'
AND tbls.name = 'プライマリーキー(PK)を取得したいテーブル名'
INNER JOIN sys.index_columns AS idx_cols ON
key_const.parent_object_id = idx_cols.object_id
AND key_const.unique_index_id = idx_cols.index_id
INNER JOIN sys.columns AS cols ON
idx_cols.object_id = cols.object_id
AND idx_cols.column_id = cols.column_id
