SQL CE Compact 3.5 Столбцы идентификаторов для таблицы

Есть ли запрос, который я могу написать для INFORMATION_SCHEMA или для системных таблиц, чтобы определить, является ли столбец идентификатором в SQL CE версии 3.5?


person rxm0203    schedule 01.11.2009    source источник
comment
Вот веб-ссылка на ответ: social.msdn.microsoft.com/Forums/en-US/sqlce/thread/   -  person rxm0203    schedule 02.11.2009


Ответы (2)


Используйте COLUMNPROPERTY . Для справки

а) COLUMNPROPERTY (Transact-SQL)

б) Столбцы идентификации

person priyanka.sarkar    schedule 01.11.2009
comment
Функция COLUMNPROPERTY недоступна в SQL CE Compact 3.5. Вот ссылка для справки: msdn.microsoft.com/en-us/ библиотека/ms174077.aspx - person rxm0203; 01.11.2009

Попробуйте следующий запрос:

;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
person Camilo A. Villa Naranjo    schedule 09.05.2015