1. ホーム
  2. sql

[解決済み] テーブルのカラムのリストとデータ型、NOT NULL、PRIMARY KEY制約を取得するSQLサーバーのクエリ

2022-04-01 05:17:02

質問

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

しかし今、私はまた、同じテーブルで、列に対して取得する必要があります - 。 TRUE そのカラムが主キーである場合。

どうすればいいのでしょうか?

私の期待する出力は

Column name | Data type | Length | isnull | Pk

解決方法は?

一部の列で行が重複しないように、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 以上で動作します。

スキーマを使用している場合は YourTableNameYourSchemaName.YourTableName ここで YourSchemaName は実際のスキーマ名であり YourTableName は実際のテーブル名です。