ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

SQL中的主键,候选键,外键,主码,外码

2021-01-03 13:04:16  阅读:293  来源: 互联网

标签:候选 外码 标识 记录 外键 数据表 主键 属性


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

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

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

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

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

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

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

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

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

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

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

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

标签:候选,外码,标识,记录,外键,数据表,主键,属性
来源: https://www.cnblogs.com/SnowSec/p/14225207.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有