暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

数据库系统原理

HelloYuChen 2021-04-21
1351

候选码、主码、全码、外码、主属性、主键、主关键字、非主属性

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

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

    • 非空性:不能为空

    • 有些时候也把码称作“键”


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

    • 标识性:一个数据表的所有记录都具有不同的候选键

    • 最小性:任一候选键的任何真子集都不能唯一标识一个记录(比如在成绩表中(学号,课程号)是一个候选键,单独的学号,课程号都不能决定一条记录)

    • 非空性:不能为空

    • 候选键是没有多余属性的超键

    • 举例:学生ID是候选码,那么含有候选码的都是码。

    • 少部分地方也有叫超级码的,但是见得不多


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

    • 唯一性:一个数据表只能有一个主键

    • 标识性:一个数据表的所有记录都具有不同的主键取值

    • 非空性:不能为空

    • 人为的选取某个候选码为主码


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

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

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

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

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

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

范式与函数依赖

第一范式(1NF) 非码的非平凡

| ↓ 消除非主属性对码的部分函数依赖

第二范式(2NF)

↓ 消除非主属性对码的传递函数依赖

第三范式(3NF)

↓ 消除主属性对码的部分和传递函数依赖

BC范式(BCNF)

↓ 消除非平凡且非函数依赖的多值依赖

第四范式(4NF)

↓消除不是由候选码所蕴含的连接依赖

第五范式(5NF)


文章转载自HelloYuChen,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论