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

作者:进击的蛙蛙 时间:2024-01-21 10:45:05 

一、定义与作用

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

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

二、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表,右击,选择<设计>

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

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

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

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

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

2)设置外键

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

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

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

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

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

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

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

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

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

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

 刚开始上课的时候我就有点搞不清主键表与外键表,特别是设置的这张图里,

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

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

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

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

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

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

补充:SQL Server的主键与外键约束

SQL Server的主键与外键约束SQL Server有许多的重要知识,开始也说过许多的SQL知识了。SQL Server中的约束也是一个重要性的知识,下面我来说说关于SQL Server约束的知识。

首先我们来说说SQL sever的主键约束:主键是唯一标识表中每一行的列或一组列。可以使用 PRIMARY KEY 约束为表创建主键。如果主键只包含一列,则可以将 PRIMARY KEY 约束定义为列约束,如果主键有两列或更多列,则必须使用 PRIMARY KEY约束作为表约束(代码如图所示):

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

每个表只能有一个主键。参与主键的所有列必须定义为 NOT NULL。如果没有为这些列指定 NOT NULL 约束,SQL Server会自动为所有主键列设置 NOT NULL 约束。在创建主键时,SQL Server还会自动创建唯一的聚簇索引(如果指定,则为非聚集索引)。

接下来就是外键约束:SQL Server外键约束简介外键是一个表中的一列或一组列,它唯一地标识另一个表的行。 vendor_groups 和vendor表,它们的结构(如图所示):

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

每个供应商属于供应商组,每个供应商组可能有零个或多个供应商。 vendor_groups 和 vendors 表之间的关系是一对多的。对于 vendors 表中的每一行,始终可以在 vendor_groups 表中找到相应的行。但是,如果使用当前表创建方式,可以在vendors 表中插入一行而不在 vendor_groups 表中显示相应 的行。 还可以删除 vendor_groups 表中的行,而无需更新或删除 vendors 表中导致 vendors 表中存在孤立的行。要强制执行 vendor_groups 和 vendors 表中的数据之间的链接,需要在 vendors 表中建立外键。要创建外键,请使用 FOREIGN KEY 约束。以下语句删除 vendors 表并使用 FOREIGN KEY 约束重新创建它:

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

现在,vendor_groups 表称为父表,该表是外键约束引用的表。 vendors 表称为子表,该表是应用外键约束的表。

来源:https://blog.csdn.net/m0_51532253/article/details/124156180

标签:sqlserver,主键,外键
0
投稿

猜你喜欢

  • Python进阶之使用selenium爬取淘宝商品信息功能示例

    2022-04-26 04:55:15
  • python3模拟百度登录并实现百度贴吧签到示例分享(百度贴吧自动签到)

    2023-07-08 23:15:23
  • JavaScript中实现字符串的取左取右(实现left和right功能)

    2009-07-20 12:39:00
  • Pytorch之parameters的使用

    2022-05-22 21:06:01
  • 在VSCode中搭建Python开发环境并进行调试

    2021-09-20 23:19:13
  • Linux安装MySQL5.6.24使用文字说明

    2024-01-24 22:20:54
  • 关于递归运算的顺序测试代码

    2023-08-24 13:04:16
  • 用Python将IP地址在整型和字符串之间轻松转换

    2021-03-31 16:37:16
  • 设置python3为默认python的方法

    2023-07-11 19:24:49
  • python实现linux下使用xcopy的方法

    2022-08-16 07:52:09
  • 完美实现js选项卡切换效果(一)

    2024-04-23 09:28:24
  • python中关于property的最详细使用方法

    2023-07-23 15:35:26
  • python 性能提升的几种方法

    2022-05-21 06:38:18
  • Python logging模块原理解析及应用

    2022-04-08 11:14:32
  • javascript面向对象编程(三)

    2008-03-07 13:19:00
  • python设计模式之装饰器模式

    2023-04-28 07:55:40
  • Python第三方包PrettyTable安装及用法解析

    2023-02-22 03:19:16
  • mysql中的日期相减的天数函数

    2024-01-20 01:00:51
  • QQ影音感念亲恩皮肤,不只是大按钮这么简单

    2009-01-04 14:16:00
  • vscode通过Remote SSH远程连接及离线配置的方法

    2022-01-09 00:31:08
  • asp之家 网络编程 m.aspxhome.com