如何在sql server中设置两个主键

 我来答
哎呀……18a91a6
推荐于2017-11-23 · TA获得超过4.2万个赞
知道大有可为答主
回答量:7246
采纳率:76%
帮助的人:3019万
展开全部
首先一个表是不能有两个主键的。但是可以有两个字段组合成一个主键,这就是为什么有时候表里为什么会有两个字段都有主键的标志,那是因为他们组合成了一个主键了。我们可以先删除了原来的主键再用类似下面SQL语句建立:

alter table 你的表名 add constraint pk_name primary key (字段1,字段2)

或者在表设计器里面按住ctrl选中要设置主键的两列再设置主键就OK了
镧锗镱镥铽镝钐
2018-03-30 · TA获得超过2252个赞
知道小有建树答主
回答量:23
采纳率:0%
帮助的人:1.1万
展开全部

主键是数据库表的一个重要属性,建立主键可以避免表中存在完全相同的记录,也就是说主键在一张表中的记录值是唯一的。   

建立主键有两种方法:一种是在数据库提供的GUI环境中建立,另一种是通过SQL语句执行建立,下面分别介绍。   

1、在数据库提供的GUI环境中建立。   

输入表信息后按Ctrl键同时选中多行,然后点上面的主键按钮就行了。   

2、通过SQL语句执行建立。又分两种,一是在建表语句中直接写,二是建表之后更改表结构。  

在建表语句中直接写:   

Create   Table   表名   (字段名1   Int   Not   Null,   

字段名2   nvarchar(13)   Not   Null   Primary   Key   (字段名1,   字段名2),   

字段名3…………   

字段名N…………   )

建表之后更改表结构:

CREATE   TABLE   表名   (字段名1   Int   Not   Null,   

字段名2   nvarchar(13)   Not   Null   

字段名3…………   

字段名N…………)   

GO

ALTER   TABLE   表名   WITH   NOCHECK   ADD     

CONSTRAINT   [PK_表名]   PRIMARY   KEY     NONCLUSTERED     

(   

[字段名1],   

[字段名2]   

)   

GO

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2015-09-30
展开全部
其实很简单的,举个例子说明如何设置两个主键

--创建学生表
CREATE TABLE 学生表
(
学号 int NOT NULL PRIMARY KEY (学号),
姓名 nvarchar(20) NOT NULL,
性别 bit,
出生日期 int not null,
系编码 int not null
)

--创建课程表
CREATE TABLE 课程表
(
课程号 int NOT NULL PRIMARY KEY (课程号),
课程名 nvarchar(100) NOT NULL,
选修课号 int,
学分 decimal(2,1)
)

--创建选课表
CREATE TABLE 选课表
(
学号 int not null,
课程号 int not null,
成绩 decimal(3,1)
primary key(学号,课程号) --将学号、课程号设为主键
)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
一颗程序猿o_0
2017-03-04 · TA获得超过6297个赞
知道大有可为答主
回答量:5403
采纳率:77%
帮助的人:1347万
展开全部

在设计视图中,按住ctrl键,分别选中那两个列, 然后点一下工具栏上的主键按钮(钥匙形状)

或者使用代码:

CREATE TABLE

(

)

CREATE TABLE [myTable]
(
    [Id1] int not null,
    [Id2] int not null,
    [Name] nvarchar(50) not null,
    ......
    PRIMARY KEY([Id1],[Id2])
)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
atwt27
2016-11-25 · TA获得超过149个赞
知道小有建树答主
回答量:216
采纳率:100%
帮助的人:110万
展开全部
1、右击表名→设计
2、选中两列→右击→设为主键
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式