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表,右击,选择<设计>
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 Server的主键与外键约束
SQL Server的主键与外键约束SQL Server有许多的重要知识,开始也说过许多的SQL知识了。SQL Server中的约束也是一个重要性的知识,下面我来说说关于SQL Server约束的知识。
首先我们来说说SQL sever的主键约束:主键是唯一标识表中每一行的列或一组列。可以使用 PRIMARY KEY 约束为表创建主键。如果主键只包含一列,则可以将 PRIMARY KEY 约束定义为列约束,如果主键有两列或更多列,则必须使用 PRIMARY KEY约束作为表约束(代码如图所示):
每个表只能有一个主键。参与主键的所有列必须定义为 NOT NULL。如果没有为这些列指定 NOT NULL 约束,SQL Server会自动为所有主键列设置 NOT NULL 约束。在创建主键时,SQL Server还会自动创建唯一的聚簇索引(如果指定,则为非聚集索引)。
接下来就是外键约束:SQL Server外键约束简介外键是一个表中的一列或一组列,它唯一地标识另一个表的行。 vendor_groups 和vendor表,它们的结构(如图所示):
每个供应商属于供应商组,每个供应商组可能有零个或多个供应商。 vendor_groups 和 vendors 表之间的关系是一对多的。对于 vendors 表中的每一行,始终可以在 vendor_groups 表中找到相应的行。但是,如果使用当前表创建方式,可以在vendors 表中插入一行而不在 vendor_groups 表中显示相应 的行。 还可以删除 vendor_groups 表中的行,而无需更新或删除 vendors 表中导致 vendors 表中存在孤立的行。要强制执行 vendor_groups 和 vendors 表中的数据之间的链接,需要在 vendors 表中建立外键。要创建外键,请使用 FOREIGN KEY 约束。以下语句删除 vendors 表并使用 FOREIGN KEY 约束重新创建它:
现在,vendor_groups 表称为父表,该表是外键约束引用的表。 vendors 表称为子表,该表是应用外键约束的表。
来源:https://blog.csdn.net/m0_51532253/article/details/124156180


猜你喜欢
- 刚刚有人问我二年前写的那个小三角的效果还能作出什么样的效果,我正在看电视,画面上出现了这样一个小灯笼,于是,我就说,可以作个小灯笼玩玩。于是
- SPAN 和 DIV 的区别在于,DIV(division)是一个块级元素,可以包含段落、标题、表格,乃至诸如章节、摘要和备注等。而SPAN
- 1、如何快速找到多个字典中的公共键(key)实际案例:西班牙足球甲级联赛,每轮球员进球统计:第一轮:{'苏亚雷斯': 1,
- 限制只能输入数字// -----------------------------------------------------------
- 终极版终于有时间给大家分享了!!!。我们先看一下效果图。1:登录界面:2:查询数据库所有的内容!3:链接数据库:4:最终的打包!话不多说直接
- 每天不同时间段通过微信发消息提醒女友简介有时候,你很想关心她,但是你太忙了,以至于她一直抱怨,觉得你不够关心她。你暗自下决心,下次一定要准时
- 先由exp把数据卸出到文件系统, 产生一个.dmp文件, 然后必要时再由imp将数据装入数据库. 对于一般中小型数据库来说, 全数据库的ex
- 本文实例为大家分享了Python实现打乒乓小游戏的具体代码,供大家参考,具体内容如下源码奉上:import sysimport cfgimp
- time模块1:概述时间表示的分类时间戳格式化的时间字符串结构化时间时间戳:时间戳表示的是从1970年1月1日整0点到目前秒的偏移量,数据类
- Python assert 语句,又称断言语句,可以看做是功能缩小版的 if 语句,它用于判断某个表达式的值,如果值为真,则程序可以继续往下
- 1比如python提倡简单实用的思想,它就没有switch语句,如果要实现switch语句的效果 的话可以通过2个方法来写把 (1)通过if
- 首先是不知道怎么忽然mysql用命令行,workbench都登录不了,都提示'Access denied for user '
- Python2.6 之前:字符串转换为整形和浮点型>>>import string>>>string.a
- User Centered Design 以用户为中心的设计,一说到这个很多人马上想到互联网和软件的设计,因为在IT、互联网行业提得最多。其
- 目录一. 加载数据1. 继承Dataset类并重写关键方法2. 使用Dataloader加载数据二. 模型设计三. 训练四. 测试结语pyt
- Django 基本命令本节主要是为了让您了解一些django最基本的命令,请尝试着记住它们,并且多多练习下1. 新建一个 django pr
- 今天刚看到ChinaUI.com新改版的网站,觉得优艾网是越来越漂亮了,这次的变化的确是挺大的。一早大概的看了一下就关了,后来晚上又打开看时
- 有时候,我们在某一重要的时间段需要监控某张表的变化情况,包含插入、更新、删除。举例来说,当我们把数据导出到外部的系统时,我们希望导出的是全部
- 有时候,为了获取查询结果的部分数据,需要对变量进行一些处理,在网上查了一圈,只发现了这两个方法:返回查询结果的切片在返回给前端的结果中,通过
- 表单内有两个提交按钮,要实现当点击不同的提交按钮时,分别进行两个不同的处理过程,在这里有实现表单多按钮提交action的处理方法分享给大家。