您的当前位置:首页>资讯 > 正文

天天速读:关系型数据库的主键和外键

  • 2023-06-12 14:34:50 来源:商业新知网
在之前的文章中,我介绍了关系型数据库中的关系、基数、实体关系图、鸦爪图和业务规则等概念,这篇文章会继续讨论数据库的另一个重要的概念“键”。理解这部分的内容后,我们对数据索引的认识会上升到一个新高度。

1.什么是“键”?

在解释概念之前,让我们先回顾一下此前的内容。

图 “SKU”、“供应商”、“采购订单”实体关系图


【资料图】

首先我们看“SKU”和“供应商”的关系,简单来说,这是“一对多”的关系,如果用更加严谨的表达,那就是“0或1个”SKU,是由”0或多个“供应商来供货的。

这个关系的意思是SKU可能有多个供货商,也可能暂时没有货源。反过来,供应商最多只能提供某一个的SKU,或是不供应。

其次是“供应商”和“采购订单”的关系,一个供应商可以对应着“0或多个”的采购订单,而一个采购订单只能对着“1个,且仅有1个”的供应商。这些关系的具体内容都在前篇文章中已介绍过,不再重复。

什么是“键”呢?它是从英文“Keys”翻译过来的,在数据库中讨论的键主要有2种,分别是 主键 (Primary Keys,缩写PK)和 外键 (Foreign Keys,缩写FK)。

2.主键

主键就是主要的键,它是 一个或多个属性,可用于识别某个实体或表中唯一的记录 。定义很抽象,让我们来举个例子。

图 “SKU”表格

在SKU实体中的属性有件号、供应商编号、供应商名称和配额。在表格中有4条记录,哪个属性可以 识别出唯一的记录呢 ?很显然是件号,其他的属性都可能会有重复的记录,然而件号是根据一定的规则编制的,且不会重复。

主键是身份标识号,就像是人的身份证一样。全中国同名同姓的人可能有很多,不能作为主键,身份证号码是唯一的,它就可以是主键。

在数据库中,主键是自动生成的号码,按照顺序,从小到大的整数,例如“26303”。每次新增一条记录,主键的号码就自动增加1位。使用整数的好处是占用存储空间小,成本更低,而且查询的速度也更快。

由于主键是唯一的,我们在尝试添加一条新的数据之前,数据库会检查是否有重复的条目。因此,主键是一个对特定表中的每一条记录都是唯一的值。

在“供应商”实体中,哪一个属性是主键呢?可能有人会说是“供应商编号”,它看起来符合成为主键的条件。但是供应商表格里可能存在重复的供应商编号,所以仅凭一个属性是不能成为主键,我们需要把多个属性组合在一起后,它们才能变成唯一的值。

举个例子,高铁上有多个车厢,每个车厢里都有1A这个座位,我该如何对号入住呢?就需要结合车厢号和座位号,才能找到该趟车上正确的位置,例如03车1A座,这是唯一的记录。在供应商表中,属性“供应商编号”和“序号”组合在一起,它们构成了该实体中的主键,也叫做 复合键 (Composite Keys)。

图 复合键

3.外键

顾名思义,“外键”就是外来的键。在介绍概念之前,读者可能已经观察到了,有些实体的主键会出现在其他的实体之中,例如“SKU”中的“件号”也存在于“供应商”实体里。“件号”在前者的表格里是主键,那么它在其他表中的作用是什么呢?

SKU和供应商实体是一对多的关系,每个SKU可以有多个的供应商供货,而供应商只能供应某一个特定的SKU。在这种情况下,SKU是独立的或叫做父级实体,而供应商是相关的或叫做子级实体。

“件号”在SKU表中是主键,它在相关的子级表中就是外键。外键是另一个表中的主键,用于连接从属关系与父级实体。

图 主键和外键的关系

在上图的例子中,父实体是SKU,它的主键是件号。子实体是供应商表,其外键是存储在供应商表中的件号。这样做是有什么意义呢?每一个SKU,例如件号是26516,苏州X公司和常熟Y公司都可以供货。

因此,每个供应商都有自己的供应商编号和序号,苏州X公司的编号是1475,序号是6,常熟Y公司的编号是1369,序号是5,但他们两家的件号的值都是26516,这是供应商表中的外键。

件号是SKU表的主键,它是一个唯一的值,可以识别SKU表中的每一行。然后在供应商表中,主键是供应商编号和序号,但每个供应商也有一个件号,它是一个有效的值,来自这个SKU表。

重要的一点是,供应商编号和序号是供应商的唯一标识符。件号不需要作为供应商主键的一部分,因为这个表已经有一个完整的唯一识别主键。 这只是一个额外的支持信息 ,帮助我们在这两个表之间建立数据关系。

总结一下, 主键是帮助我们唯一地识别表中的每一条记录的属性 。所以它们对每一条记录都必须是唯一的,只要我们有了这个键,就能帮助我们找到一行中的所有附加信息。

外键是存储在从属实体中的属性 ,它向我们展示了从属实体中的记录是如何与独立实体相关的。所以,外键是另一个表的主键,而这个表是子表或从属实体。

标签:

推荐阅读

天天速读:关系型数据库的主键和外键

外键是存储在从属实体中的属性,它向我们展示了从属实体中的记录是如何

热头条丨小孩被“客服”套路诈骗6万余元 衡南警方全额追回

原标题:小孩被“客服”套路诈骗6万余元衡南警方全额追回为表谢意,王

扎克伯格宣布大胆计划:将 AI 融入Meta 的每一个产品|全球百事通

Meta前Facebook首席执行官马克·扎克伯格有一个大胆的新计划,目的是为

全球速看:进度过七成半 全国冬小麦收获2.39亿亩

​“三夏”时节,各地多措并举抢收抢种,农业生产有序推进。农业农村部

天天微动态丨民生银行:今起调整人民币存款利率

【大河财立方消息】6月12日,民生银行公告称,决定自2023年6月12日起调

猜您喜欢

【版权及免责声明】凡注明"转载来源"的作品,均转载自其它媒体,转载目的在于传递更多的信息,并不代表本网赞同其观点和对其真实性负责。亚洲在线网倡导尊重与保护知识产权,如发现本站文章存在内容、版权或其它问题,烦请联系。 联系方式:8 86 239 5@qq.com,我们将及时沟通与处理。

教育