一文搞懂候选码、主码、全码、外码、主属性、主键、主关键字、非主属性清晰总结

一文搞懂候选码、主码、全码、外码、主属性、主键、主关键字、非主属性清晰总结首先说明键字 码字 所以主键 主码 主关键字 候选键 候选码 候选关键字 所谓关系键 指的是一个表中的一个 或一组 属性 用来标识该表的每一行或与另一个表产生联系

大家好,欢迎来到IT知识分享网。

一、讲解

1、码=超键:能够唯一标识一条记录的属性或属性集。

2、候选键=候选码:能够唯一标识一条记录的最小属性集

3、主键=主码:某个能够唯一标识一条记录的最小属性集(是从候选码里人为挑选的一条)

4、主属性 包含在任一候选码中的属性称主属性。简单来说,主属性是候选码所有属性的并集

非主属性 不包含在候选码中的属性称为非主属性。 非主属性是相对于主属性来定义的。

5、外键(foreign key):子数据表中出现的父数据表的主键,称为子数据表的外键。

6、全码:

当所有的属性共同构成一个候选码时,这时该候选码为全码。(教师,课程,学生)假如一个教师可以讲授多门课程,某门课程可以有多个教师讲授,学生可以听不同教师讲授的不同课程,那么,要区分关系中的每一个元组,这个关系模式R的候选码应为全部属性构成 (教师、课程、学生),即主码。

7、代理键:

当不适合用任何一个候选键作为主键时(如数据太长等),添加一个没有实际意义的键作为主键,这个键就是代理键。(如常用的序号1、2、3)

8、自然键:

自然生活中唯一能够标识一条记录的键(如身份证)

二、例子

下面举例说明

课本上的定义过于笼统,下面我用一张学生成绩信息表给大家详细的说一下:

学生成绩信息表中有(学号、姓名、性别、年龄、系别、专业等)

超键/码:

由于学号能确定一个学生,因此学生表中含有学号的任意组合都为此表的超键。如:(学号)、(学号,姓名)、(学号,性别)等

候选键:

学号唯一,而且没有多余属性,所以是一个候选键

姓名唯一,而且没有多余属性,所以是一个候选键

主键:

主键就是候选键里面的一个,是人为规定的,例如学生表中,我们通常会让“学号”做主键,学号能唯一标识这一个元组。

外键:

外键就很简单了,假如我们还有一个教师表,每个教师都有自己的编号,假设老师编号在教师表中是主键,在学生表中它就是外键。

三、练习

1.答案:

(1)候选关键字2个:(学号),(身份证号) (2)主关键字:(学号) (3)主属性2个:学号,身份证号 (4)非主属性2个:姓名,系别 
  1. 答案:
(1)候选关键字1个:(学号,课程号) (2)主关键字:(学号,课程号) (3)主属性2个:学号,课程号 (4)非主属性1个:成绩 (5)外部关键字:学号(引用学生信息表中的学号),课程号(引用课程信息表中的课程号) 

3.答案:

(1)候选关键字1个:(课程号) (2)主关键字:(课程号) (3)主属性1个:课程号 (4)非主属性2个:课程名,学分 

原文: https://blog.csdn.net/sumaliqinghua/article/details/#commentBox

结语

我们下期再见。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/114167.html

(0)
上一篇 2025-12-10 13:26
下一篇 2025-12-10 13:45

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信