首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >自动增量唯一标识符

自动增量唯一标识符
EN

Stack Overflow用户
提问于 2010-05-15 04:54:03
回答 4查看 40.4K关注 0票数 25

基本上,我希望以类似于identity的方式使用唯一标识符。我不想向其中插入值,它应该自动插入值,每行不同的值。我无法在唯一标识符类型的列上设置自动增量(属性' autoincrement‘被设置为false,并且不可编辑)。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-05-15 04:57:42

或者更好:使用newsequentialid()作为UNIQUEIDENITIFER列的默认值。这将为您提供一系列顺序的GUID。

代码语言:javascript
运行
复制
CREATE TABLE dbo.YourTable   
   (SerialID UNIQUEIDENTIFIER 
        CONSTRAINT DF_SerialID DEFAULT newsequentialid(),
     .... (other columns)......
   )

问题是: newsequentialid只能作为列默认值使用--您不能将其作为函数或任何东西调用。但这似乎符合您的要求。

UPDATE: SQL Server Management Studio中似乎存在一个公认的错误,该错误阻止在交互式表设计器中将newsequentialid()指定为列的默认值。

请参阅:http://social.msdn.microsoft.com/Forums/en-US/sqltools/thread/cad8a4d7-714f-44a2-adb0-569655ac66e6

解决方法:在不指定任何默认值的情况下创建表,然后在普通查询窗口中键入以下T-SQL语句并运行:

代码语言:javascript
运行
复制
ALTER TABLE dbo.YourTable
    ADD CONSTRAINT DF_SerialID DEFAULT newsequentialid() FOR SerialID

这应该能起到作用!

票数 32
EN

Stack Overflow用户

发布于 2010-05-15 05:20:23

我猜你指的是SQLServer而不是C#..。

将该列设置为主键和ROWGUID

RowGuid http://img341.imageshack.us/img341/8867/sqlserverrowguid.png

票数 7
EN

Stack Overflow用户

发布于 2013-10-10 20:17:09

我认为

代码语言:javascript
运行
复制
CREATE TABLE dbo.YourTable
(
    SerialID UNIQUEIDENTIFIER PRIMARY KEY DEFAULT newsequentialid()
)

更简单

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2837559

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档