关系型数据库 超键 候选键 主键 外键的区别

例子

?
1
2
3
4
5
6
7
8
学号 姓名 性别 年龄 系别 专业
 
20020612 李辉 男 20 计算机 软件开发
20060613 张明 男 18 计算机 软件开发
20060614 王小玉 女 19 物理 力学
20060615 李淑华 女 17 生物 动物学
20060616 赵静 男 21 化学 食品化学
20060617 赵静 女 20 生物 植物学

1.超键

在关系中能唯一标识元组的属性集称为关系模式的超键。

于是我们从例子中可以发现 学号是标识学生实体的唯一标识。那么该元组的超键就为学号。

除此之外我们还可以把它跟其他属性组合起来,比如:

学号,性别

学号,年龄

这样也是超键

2.候选键

不含多余属性的超键为候选键。

根据例子可知,学号是一个可以唯一标识元组的唯一标识,因此学号是一个候选键,实际上,候选键是超键的子集,比如 (学号,年龄)是超键,但是它不是候选键。因为它还有了额外的属性。

3.主键

用户选择的候选键作为该元组的唯一标识,那么它就为主键。

简单的说,例子中的元组的候选键为学号,但是我们选定他作为该元组的唯一标识,那么学号就为主键。

4.外键

外键是相对于主键的,比如在学生记录里,主键为学号,在成绩单表中也有学号字段,因此学号为成绩单表的外键,为学生表的主键。

总结

主键为候选键的子集,候选键为超键的子集,而外键的确定是相对于主键的。



a.超键:在关系模式中,能唯一标识元组的属性集称为超键。

b.候选键 :如果一个属性集能唯一标识元组,且有不包含多余属性,那么这个属性集称为候选键;也即:候选键是没有多余属性的超键。

那么超键可以看作是带有其他有多余属性的候选键,也即候选键带上任意个其他属性可被视为超键。
c.主键:关系模式中用户正在使用的候选键称主键(primary key)。一般,如不加说明,键是指主键。
举例:
1.(假设姓名无重复)
姓名,学号,年龄
a,1,20
b,2,30
c,3,23
姓名唯一,是个超键
学号唯一,是个超键
(姓名,年龄)唯一 ,是个超键
(学号,努力)唯一,是个超键
姓名唯一,且没有其他多余属性,是个候选键
学号唯一,且没有其他多余属性,是个候选键

考虑方便查询,我们使用学号作为主键;也可以根据习惯,使用姓名作为主键;即选中的候选键就是主键
d.外键
在关系模式R中,如果某属性集是其他模式的候选键,那么该属性集对模式R来说就是外键。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值