SQL Server 使用没有主键的聚集索引创建表

2024-01-31

是否可以从 SQL Server 2008 中的非主键创建表语句创建聚集索引?

这样做的目的是针对 SQL Azure 中的表,因此我不能选择先创建表,然后在表上创建聚集索引。

Edit:显然是 FluentMigrator 导致了我的问题,它的版本表没有聚集索引,因此尝试创建版本控制表而不是我的表时出错。


是的,可以创建非主键的聚集索引。只需使用一个CREATE CLUSTERED INDEX https://msdn.microsoft.com/en-us/library/ms186342.aspx陈述。

CREATE TABLE dbo.myTable (
    myTableId int PRIMARY KEY NONCLUSTERED
    myColumn int NOT NULL
)

CREATE CLUSTERED INDEX myIndex ON dbo.myTable(myColumn)

在 Azure SQL 数据库 v12 版本之前,必须拥有聚集索引才能将任何数据插入表中。作为Azure SQL 数据库 v12 https://azure.microsoft.com/en-us/documentation/articles/sql-database-v12-whats-new/,现在支持堆(没有聚集索引的表)。

如果您的数据库是在 2016 年 6 月之前创建的,则以下是升级到版本 12 的说明 https://azure.microsoft.com/en-us/documentation/articles/sql-database-upgrade-server-portal/.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SQL Server 使用没有主键的聚集索引创建表 的相关文章