SQL Server:主键与外键设置与相关理解

Posted 进击的蛙蛙

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server:主键与外键设置与相关理解相关的知识,希望对你有一定的参考价值。

一、定义与作用

主键:表中能够唯一地辨别事物的属性。通过主键能够查询出表中一条完整的记录,同时使用主键能防止表中出现重复的记录,避免了数据的冗余。

外键:通俗讲就是表中一个属性是来自另一张表的主键,该属性被称为该表的外键,外键可以有不止一个。外键存在的意义就是将事物与事物之间联系起来。

二、SSMS设置表的主键与外键

1、利用SQL语句建立查询设置

举了一个学生、课程以及学生成绩关系表的例子:

--代码
create table [表名] (
    属性名 类型 primary key,
    属性名 类型 foreign key references [外键来自的表](外键的属性名),
    属性名 类型 not null,
    属性名 类型 null,
        ···  ···);

--实例
create table Student(                        --创建Student表
	Stu_id varchar(10) primary key,          --学号Stu_id设置为主键
	Stu_name nvarchar(10) not null,          --学生姓名
	Stu_sex nvarchar(2) default '男');       --学生性别,设置默认值为'男'


create table Course(                         --创建课程信息表Course
	Course_id varchar(4) primary key,        --课程编号Course_id设置为主键
	Course_name varchar(10) not null);       --课程姓名


create table StudentGrade(                                            --创建成绩表
	stu_id varchar(10) foreign key references Student(Stu_id),        --学生学号设置为外键
	Course_id varchar(4) foreign key references Course(Course_id),    --课程号设置为外键
	Grade int null);                                                  --学生成绩

2、利用鼠标点击操作创建(SSMS环境下)

     1) 设置主键 

a.在已创建Student表的前提下,点击Student表,右击,选择<设计>

         b.选择属性Stu_id,右击,选择设置主键

         设置完成,Course表主键设置同上。

        2)设置外键

a.选择StudentGrade表,如1)中a所示选择<设计>

b.选择属性Stu_id,右击,选择<关系>

c.在弹出的窗口选择<添加> 

d.点击表和列规范最右边的三个小点(白色背景可能看不到,但点最右边也差不多了)

e.关系名可以重新编辑,最好是能让自己记得住或看得懂含义的名字。将主键表和外键表设置完后点击右下方确认即可。

 三、主键表与外键表(个人的总结与反思...)

 刚开始上课的时候我就有点搞不清主键表与外键表,特别是设置的这张图里,(假设正在设置的这张StudentGrade表称为本表,其他表相对地称为外表),我认为外键表应该是指外键本来所在的表,即外表,因此应该设置为Student才对,但是这个框框一直编辑不了;而主键表应该指我正在编辑的这张StudentGrade表才对,但是当选择StudentGrade之后,下面列选项的框框就变成空的,没有列可选。

 但是将两个操作互换后又能得到想要的结果,所以当时就半懵半混过去了。

然后偶然听到郝斌老师的课之后才恍然大悟

        首先,主键表应该是指外键所来自的那个表,即例子中的Student表,在Student表中Stu_id是该表的主键,因此该表称为主键表;而外键表则指Stu_id扮演外键的时候所在的表,即例子中StudentGrade表。

sql用命令创建主键与外键。

参考技术A

1、为了方便大家理解,使用一个例子来帮助大家理解。意思大概就是通过引用表二中的字段完成对表一字段的约束。方法:

2、这里一共两个表,先创建外键表,因为先有外键,主键才能引用。首先创建数据库,新建查询。

3、新建外键表【teacher】,输入命令:create table teacher。添加需要的字段teacher_xingming并设置它为【主键】。输入命令:teacher_xingming nchar(10) primary key,

4、选中需要执行的命令行,单击【执行】,下方会有是否成功的提示。现在对表进行刷新操作后,会发现已经成功创建了一个新表【teacher】。

5、接下来就要创建学生表了,create table student(\\tstudent_xingming nchar(10) primary key not null,——该程序段意思为创建一个【student】表,表中新建一个主键【student_xingming字段,类型为nchar(10) ,并不允许为空。】

6、继续写,输入:student_banji nchar(10) not null,——表中新建一个【student_banji字段,类型为nchar(10) ,并不允许为空。】

7、创建外键,输入命令student_jiaoshi  nchar(10) foreign key references teacher(teacher_xingming)看起来很长,实际意思很简单:表中新建一个【student_jiaoshi字段】,它是外键,nchar(10)类型,它来至 teacher_xingming中的内容。

8、选中,点击【执行】,没有错误,就说明成功了。刷新一下表,看看是不是多了一个表【student】?所有约束已经创建好了。

9、来试一下看看是否真正实现所说的功能。打开【teacher表】,填写“刘老师”。打开【student表】,前面任意填,最后填写“刘老师”,没有错误说明没问题。

10、如何想测试约束是否真的有效,填写其他内容,看看是否成功,只要不是【teacher】字段中的内容,他就会报错。

以上是关于SQL Server:主键与外键设置与相关理解的主要内容,如果未能解决你的问题,请参考以下文章

sql server的主键与外键问题

sql server 主键与外键约束无法创建

如何分清SQL数据库中的主键与外键

数据库中 主键与外键的区别?

数据库中的主键与外键的关系

数据库的主键与外键