データ型、NOT NULL、PRIMARY KEY制約とともにテーブル内の列のリストを取得するSQLサーバークエリ 質問する

データ型、NOT NULL、PRIMARY KEY制約とともにテーブル内の列のリストを取得するSQLサーバークエリ 質問する

特定のテーブル内の列のリスト、それに関連付けられたデータ型 (長さを含む)、およびそれらが null でないかどうかを取得するには、SQL サーバーでクエリを作成する必要があります。そして、私はここまでの作業を行うことができました。

しかし今度は、同じテーブル内の列に対しても、TRUEその列が主キーであるかどうかを取得する必要があります。

これをどうやってやるのですか?

期待される出力は次のとおりです。

Column name | Data type | Length | isnull | Pk

ベストアンサー1

一部の列で行が重複するのを避けるには、system_type_id ではなく user_type_id を使用します。

SELECT 
    c.name 'Column Name',
    t.Name 'Data type',
    c.max_length 'Max Length',
    c.precision ,
    c.scale ,
    c.is_nullable,
    ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM    
    sys.columns c
INNER JOIN 
    sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN 
    sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN 
    sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
    c.object_id = OBJECT_ID('YourTableName')

実際のテーブル名に置き換えるだけですYourTableName。SQL Server 2005 以降で動作します。

スキーマを使用している場合は、 を に置き換えます。YourTableNameここでYourSchemaName.YourTableNameYourSchemaNameは実際のスキーマ名、YourTableNameは実際のテーブル名です。

おすすめ記事