カラムがSQLCEバージョン3.5のIDカラムであるかどうかを判断するために、INFORMATION_SCHEMAまたはシステムテーブルに対して記述できるクエリはありますか?
2087 次
2 に答える
0
于 2009-11-01T06:59:49.390 に答える
0
次のクエリを試してください。
;WITH PK_INFO AS (SELECT CON.TABLE_CATALOG, CON.TABLE_SCHEMA, CON.CONSTRAINT_NAME, USO.COLUMN_NAME
FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS CON
JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE USO ON CON.CONSTRAINT_NAME = USO.CONSTRAINT_NAME
AND CON.TABLE_CATALOG = USO.TABLE_CATALOG AND CON.TABLE_SCHEMA = USO.TABLE_SCHEMA
WHERE CON.TABLE_NAME = 'YOUR_TABLE'
AND CON.CONSTRAINT_TYPE = 'PRIMARY KEY'
) SELECT DISTINCT CASE WHEN (PK.COLUMN_NAME IS NULL) THEN 0 ELSE 1 END AS COLUMN_IS_PRIMARYKEY, *
FROM INFORMATION_SCHEMA.COLUMNS COL
LEFT JOIN PK_INFO PK on COL.COLUMN_NAME = PK.COLUMN_NAME WHERE COL.TABLE_NAME = 'YOUR_TABLE' ORDER BY COL.ORDINAL_POSITION ASC
于 2015-05-09T05:53:23.003 に答える