或者更好:使用newsequentialid()
作为UNIQUEIDENITIFER列的默认值.这将为您提供一系列有序的guid.
CREATE TABLE dbo.YourTable
(SerialID UNIQUEIDENTIFIER
CONSTRAINT DF_SerialID DEFAULT newsequentialid(),
.... (other columns)......
)
问题是:newsequentialid的默认列是only,您不能将其作为函数或任何东西调用.但这似乎符合你的要求.
UPDATE: SQL Server Management Studio中似乎存在一个公认的错误,该错误阻止在交互式表设计器中将newsequentialid()
指定为列的默认值.
请参阅:http://social.msdn.microsoft.com/Forums/en-US/sqltools/thread/cad8a4d7-714f-44a2-adb0-569655ac66e6
解决方法:在不指定任何默认值的情况下创建表,然后在普通查询窗口中键入以下T-SQL语句并运行:
ALTER TABLE dbo.YourTable
ADD CONSTRAINT DF_SerialID DEFAULT newsequentialid() FOR SerialID
这应该能奏效!