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

时间:2024-04-02 22:23:20

 

       首先说明 键字=码字,所以 主键=主码,候选键=候选码...此外也有叫做主关键字,候选关键字的也是一个意思。

键(关系键)以及数据库范式都是关系数据库的概念。所谓关系键,指的是一个表中的一个(或一组)属性,用来标识该表的每一行与另一个表产生联系

  我们先来看一下几种常见的数据库关系键:

  1、超键(super key):能够唯一标识一条记录的属性或属性集。

    • 标识性:一个数据表的所有记录都具有不同的超键
    • 非空性:不能为空

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

    • 标识性:一个数据表的所有记录都具有不同的候选键
    • 最小性:候选键的任何子集都不能唯一标识一个记录
    • 非空性:不能为空
    • 候选键是没有多余属性的超键

  3、主键(主码、primary key)某个能够唯一标识一条记录的最小属性集(与候选码的区别在于是人为挑选的一条)

    • 唯一性:一个数据表只能有一个主键
    • 标识性:一个数据表的所有记录都具有不同的主键取值
    • 非空性:不能为空
    • 选取某个候选键为主键

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

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

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

7、主属性  简单来说,候选码的属性都是主属性

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

下面举例说明

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

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

超键:

  学生表中含有学号或者身份证号的任意组合都为此表的超键。如:(学号)、(学号,姓名)、(学号,性别)等

  我们假设学生的姓名唯一,没有重名的现象。

      学号唯一,所以是一个超键
      姓名唯一,所以是一个超键
     (姓名,性别)唯一,所以是一个超键
     (姓名,年龄)唯一,所以是一个超键
     (姓名,性别,年龄)唯一,所以是一个超键

候选键:

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

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

  (姓名,性别)唯一,但是单独姓名一个属性就能确定这个人是谁,所以性别这个属性就是多余属性,所以(姓名,性别)不是候选键
  (姓名,年龄),(姓名,性别,年龄)同上,也不是候选键

主键:

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

外键:

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

做一道练习题巩固一下(假设名字可能有重复):

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

答案:

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