sql server里用alter添加主键,到底怎么写

--usePerson--createtables(idintnotnull,namenchar(10))我先创建了一个表s,然后我想用alter进行添加主键,老是报错。... --use Person
--create table s(id int not null,name nchar(10))
我先创建了一个表s,然后我想用alter进行添加主键,老是报错。
我是网上搜的写法:
1、alter table s add constraint pk_s primary key(id)
报错:找不到对象 "s",因为它不存在或者您没有所需的权限。

2、
ALTER TABLE s WITH NOCHECK ADD
CONSTRAINT [PK_s] PRIMARY KEY NONCLUSTERED
报错:表 's' 的表级别约束未指定列列表。

3、
我是用
sql server 2008
展开
 我来答
jelvis
推荐于2017-11-26 · TA获得超过5631个赞
知道大有可为答主
回答量:2480
采纳率:62%
帮助的人:823万
展开全部
alter table 你的表名 add constraint pk_s primary key (id)

注意主键数据必须唯一且不能有Null值

追问
表的数据我还没填,空的。
我的第一种方法就和你写的一样啊,不过我重新来,把创建的表命名为st,而不是此前的s。然后就可以了:alter table s add constraint pk_s primary key(id) 执行成功

constraint后面的pk_s是什么意思? 难道是pk_s会和原表名s起冲突吗
追答
不会,pk_s是约束(constraint)的名称。

你的1错误提示是没有S,应该是没建表。2错误提示是没指定列名,设置主键要指定对哪一列。
阅而立行
2019-08-14 · TA获得超过389个赞
知道答主
回答量:104
采纳率:100%
帮助的人:20万
展开全部
你需要单独执行以下create语句
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式