微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – 添加一个uniqueidentifier列并添加默认值以生成新的guid

我有以下sql命令:
ALTER TABLE dbo.UserProfiles
ADD ChatId UniqueIdentifier NOT NULL,UNIQUE(ChatId),CONSTRAINT "ChatId_default" SET DEFAULT newid()

我希望能够使此列独一无二,而且我希望每次将行添加到表中时都能生成一个新的guid.此列不是IDENTITY列,因为我已经有一列.这是分开的.如何将此列添加到已存在用户的表中.

解决方法

看这个例子:
create table test (mycol UniqueIdentifier NOT NULL default newid(),name varchar(100))
insert into test (name) values ('Roger Medeiros')
select * from test

要在填充的表上添加一个非空字段,您需要这个.

alter table test add mycol2 UniqueIdentifier NOT NULL default newid() with values

CREATE UNIQUE NONCLUSTERED INDEX IX_test ON dbo.test
(
mycol
) WITH( STATISTICS_norECOmpuTE = OFF,IGnorE_DUP_KEY = OFF,ALLOW_ROW_LOCKS = ON,ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]

原文地址:https://www.jb51.cc/mssql/81998.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐