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

el/2024/4/13 1:12:41

一、讲解

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

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

话不多说,上图:

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

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

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


http://www.ngui.cc/el/4890812.html

相关文章

【通俗易懂】关系模式范式分解教程 3NF与BCNF口诀!小白也能看懂

本来是为了复习数据库期末考试,结果找了一圈都没有发现比较好的解释,通过查阅资料和总结,为大家提供通俗易懂的解法,一听就会!并且配有速记口诀!介是你没有玩过的船新版本包含最小依赖集求法候选码求法 在…

Ubuntu添加新硬盘无损重新分区,扩充/home/,可还原

本博客适用的场景: 1.新买了一块硬盘想用它来扩充/home/或其他目录 2.之前分区有误,将根目录/home/全放在了移动硬盘上,想迁移到机械硬盘上去 3.想扩充硬盘分区,但担心数据受损 正文: 以扩充/home/为例&#xff1…

Ubuntu用户无法登陆ssh出现permission denied,please try again

适用情形: 1.使用ssh远程连接,remote等出现permission denied,please try again。 2.使用final shell等软件登陆时,密码已经正确却一直让重输密码。 3.一个账号可以登陆,另外一个账号不可登陆(多为新账号&#xff0…

【有效】2016/2013/2010 软件的安装解决方法

使用常规的kms软件进行解决 支持2016/2013/2010版本 链接:https://pan.baidu.com/s/1Dr74LmJyLdWQtx00_i3jWg 提取码:o4tw ​​​​​​​ ​​​​​​​ 链接有效麻烦点个赞~

vue无缝滚动插件

&#xff08;记录学习的过程&#xff09; 1.安装npm install --save vue-seamless-scroll 2.main.js中引入 import scroll from vue-seamless-scroll Vue.use(scroll);3.h5部分 <vue-seamless-scroll :data"listData" class"seamless-warp"><u…

vue引echarts地图

安装jquery npm install jquery --save 需要显示地图的页面添加 import $ from jquery; vue.config.js中添加 const webpack require("webpack") <div id"main" style"width: 800px;height:400px;"></div> //容器 mounted(){ …

vue使用swiper实现轮播图

(记录学习的过程) 1.安装插件 npm install vue-awesome-swiper3.1.3 --savenpm install swiper6.3.5 --save 2.main.js中引入 import VueAwesomeSwiper from vue-awesome-swiper import swiper/swiper-bundle.css Vue.use(VueAwesomeSwiper) 3. <swiper :options&qu…

echarts柱状图获取接口数据

&#xff08;记录学习的过程&#xff09; var echarts require(echarts); //固定var myChartone echarts.init(this.$refs.chartone);//定义两个上下箭头的矢量路径var up path://M286.031,265l-16.025,3L300,223l29.994,45-16.041-3-13.961,69Z;var down path://M755.2 64…

带参跳转之后作为传参获取数据

<router-link :to"{path:/credit,query:{couponId:item.id,}}"> <h5>{{item.time}} | {{item.title}}<i class"el-icon-right" style"float: right;"></i></h5> </router-link> 接收方&#xff1a; {{th…

navigator带参跳转与参数接收

1.点击跳转传参 <navigator :url"/pages/library/suremessage?titleitem.t&timeitem.x" hover-class"text-main-hover" ></navigator> 2.接收页面显示 <view>{{this.$route.query.title}}{{this.$route.query.time}}</view&g…