如何理解超键、候选键、主键、外键的含义?

本文介绍了数据库中的超键、候选键、主键和外键的概念,并通过实例解释了这些概念之间的区别。此外,还阐述了主属性与非主属性的定义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 超键:在关系模式中,能唯一标识元组的属性集称为超键(有多余的属性)
  • 候选键:在关系模式中,能唯一标识元组并且不含多余属性集称为候选键(不能有多余的属性)
  • 主键:在关系模式中,由若干个候选键中指定一个作为关键字,该关键字称为主键
  • 外键:如果在关系模式R1中的某属性集不是R1的候选键,而是关系模式R2的候选键,则该属性集对R1而言是外键(这是对于R1而言而不是对R2的)
    例如:学生(学号,姓名,性别,专业号,年龄)
    (学号,姓名)是超键,而不是候选键,学号是候选键,同时也是主键

  • 主属性:候选码中的诸属性称为主属性

  • 非主属性:不包含在任意候选码中的属性称为非主属性
    例如:成绩(学号,姓名,课程号,成绩) 注:学生无同名
    候选键:(学号,课程号),(姓名,课程号)
    主属性:学号,姓名,课程号
    非主属性:成绩

如何区分超键,候选键,主键?
超键中可能有无关属性,而主键和候选键中属性都是必要的属性。
主键和候选键的区别在于主键被数据库设计者选择的,事实上也是候选键。
例如:有三个总统候选人A,B,C,但A被选中当总统,所以A是主键

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值