SQL CE Compact 3.5 表的标识列

Posted

技术标签:

【中文标题】SQL CE Compact 3.5 表的标识列【英文标题】:SQL CE Compact 3.5 Identity columns for a table 【发布时间】:2010-12-12 00:06:55 【问题描述】:

是否可以针对 INFORMATION_SCHEMA 或系统表编写查询以确定列是否为 SQL CE 版本 3.5 中的标识列?

【问题讨论】:

这里是答案的网络链接:social.msdn.microsoft.com/Forums/en-US/sqlce/thread/… 【参考方案1】:

使用 COLUMNPROPERTY 。供你参考

一) COLUMNPROPERTY (Transact-SQL)

b) Identity Columns

【讨论】:

COLUMNPROPERTY 函数在 SQL CE Compact 3.5 中不可用。这是供您参考的链接:msdn.microsoft.com/en-us/library/ms174077.aspx【参考方案2】:

尝试以下查询:

;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

【讨论】:

以上是关于SQL CE Compact 3.5 表的标识列的主要内容,如果未能解决你的问题,请参考以下文章

SQL Server CE 中的 Shrink 和 Compact 有啥区别?

使用 SQLMetal 从 SQL Compact 3.5 数据库生成 Linq 类

MS Sync/SQL Server Compact 代码在最新版本 SQL Compact 3.5 中失败

如何将 SQL Server Compact 3.5 与实体框架一起使用

查询错误 SQL Compact Edition 3.5

SQL CE 部署 - AppHarbor - 无法加载 SQL Server Compact 的本机组件