一、讲解

首先说明 键字=码字,所以 主键=主码=主关键字,候选键=候选码=候选关键字...

所谓关系键,指的是一个表中的一个(或一组)属性,用来标识该表的每一行与另一个表产生联系

话不多说,上图:

  相信这个图已经画得很清晰了,下面逐一解释:

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

  • 标识性:一个数据表的所有记录都具有不同的超键
  • 非空性:不能为空
  • 有些时候也把码称作“键”

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

  • 标识性:一个数据表的所有记录都具有不同的候选键
  • 最小性:任一候选键的任何真子集都不能唯一标识一个记录(比如在成绩表中(学号,课程号)是一个候选键,单独的学号,课程号都不能决定一条记录)
  • 非空性:不能为空
  • 候选键是没有多余属性的超键
  • 举例:学生ID是候选码,那么含有候选码的都是码。
  • 少部分地方也有叫超级码的,但是见得不多

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

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

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

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

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

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

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

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

二、例子

下面举例说明

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

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

超键/码:

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

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

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

候选键:

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

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

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

主键:

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

外键:

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

三、练习

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

参考答案:

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个:课程名,学分

如有疑问请在评论区留言,如有帮助麻烦右上角点个赞~~蟹蟹(*^▽^*)

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

  1. 一文搞懂MySQL数据库分库分表

    如果数据量过大,大家一般会分库分表.分库需要注意的内容比较少,但分表需要注意的内容就多了. 工作这几年没遇过数据量特别大的业务,那些过亿的数据,因为索引设置合理,单表性能没有影响,所以实战中一直没用过 ...

  2. 一文搞懂 Java 线程中断

    转载自   一文搞懂 Java 线程中断 在之前的一文<如何"优雅"地终止一个线程>中详细说明了 stop 终止线程的坏处及如何优雅地终止线程,那么还有别的可以终止线程 ...

  3. 【UE·蓝图底层篇】一文搞懂NativeClass、GeneratedClass、BlueprintClass、ParentClass

    本文将对蓝图类UBlueprint的几个UClass成员变量NativeClass.GeneratedClass.BlueprintClass.ParentClass进行比较深入的讲解,看完之后对蓝图 ...

  4. 一文搞懂 Traefik2.1 的使用

    原文链接:一文搞懂 Traefik2.1 的使用 一文搞懂 Traefik2.1 的使用 核心概念 安装 ACME 中间件 灰度发布 流量复制 TCP 简单 TCP 服务 带 TLS 证书的 TCP ...

  5. 一文搞懂k近邻(k-NN)算法(一)

    原文链接 一文搞懂k近邻(k-NN)算法(一) 前几天和德川一起在学习会上讲解了k-NN算法,这里进行总结一下,力争用最 通俗的语言讲解以便更多同学的理解. 本文目录如下: 1.k近邻算法的基本概念, ...

  6. LeetCode刷题复盘笔记—一文搞懂0 - 1背包之494. 目标和问题(动态规划系列第九篇)

    今日主要总结一下动态规划0-1背包的一道题目,494. 目标和问题 题目:494. 目标和 Leetcode题目地址 题目描述: 给你一个整数数组 nums 和一个整数 target . 向数组中的每 ...

  7. 一文搞懂如何使用ArcGIS API for Python训练深度学习模型

    一文搞懂如何使用ArcGIS API for Python训练深度学习模型 文章目录 一文搞懂如何使用ArcGIS API for Python训练深度学习模型 写在前面 一.ArcGIS API f ...

  8. 网络知识扫盲,一文搞懂 DNS

    在找工作面试的过程中,面试官非常喜欢考察基础知识,除了数据结构与算法之外,网络知识也是一个非常重要的考察对象. 而网络知识,通常是很抽象,不容易理解的,有很多同学就在这里裁了跟头.为了更好地通过面试, ...

  9. LeetCode刷题复盘笔记—一文搞懂完全背包之322. 零钱兑换问题(动态规划系列第十四篇)

    今日主要总结一下动态规划完全背包的一道题目,322. 零钱兑换 题目:322. 零钱兑换 Leetcode题目地址 题目描述: 给你一个整数数组 coins ,表示不同面额的硬币:以及一个整数 amo ...

最新文章

  1. 关于Windows 2003下开启防火墙后不能通过FTP问题解决
  2. cisco 交换机 定期 自动 备份配置 -linux,交换机定时自动备份配置文件的方法
  3. duck typing java_编程语言中的鸭子类型 Duck Typing
  4. ssl提高组周六模拟赛【2018.9.22】
  5. windows下使用pthread库
  6. MySQL中的binlog日志
  7. 8类网线利弊_知识积累 | 千兆网线和百兆网线有何区别?
  8. 进阶运维:SSH无缝切换远程加密
  9. NSSM通俗易懂介绍,安装与使用
  10. 14串聚合物锂电池保护板和电路图(带均衡功能)
  11. 【数据库】SQL语句之修改语句(INSERT,UPDATE,DELETE)
  12. 三招教你如何搞定将qlv格式的腾讯视频转换为mp4格式
  13. error An unexpected error occurred “httpsregistry.npmjs.orgd3-geo-proje
  14. Odoo(OpenERP)应用实践:代发货管理
  15. 《数据结构教程(李春葆主编 第五版)》第七章源代码—树和二叉树
  16. c++面试常见题·Part 2 数据结构和STL
  17. 关于很狗的军训qwq
  18. itms-services php,APP发布系统 ipa文件上传和下载 itms-service协议
  19. 在线客服系统源码(thinkphp网页在线客服系统源码完整搭建)
  20. C语言:按要求输入如下格式的杨辉三角 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 最多输出10层

热门文章

  1. Mezzanine学习---使用自定义模板
  2. Excel技巧:合并单元格后分组排序
  3. NTFS -usnjournal监控
  4. 对话亚洲高校首个博士论文奖-裘捷中丨KDD2022
  5. 智能洗拖地机哪个品牌好一点、拖洗地机品牌排行榜前十名
  6. 今日学习在线编程题:幻数
  7. 计算机成功绘制人脑神经网络,电脑会超越人脑吗?
  8. Niushop单商户V4版强大的系统功能震撼来袭
  9. 热塑性塑料/热塑性橡胶
  10. 视频原声能去掉吗?怎么批量处理