当前位置: 首页 > news >正文

3分钟理解超键、候选键、主键

1.超键

在关系模式中,能唯一标识实体实例的任何属性集

学生(学号,姓名,性别,专业编号,年龄)

通过学号可以找到一个学生的姓名、性别、专业号、年龄,但是通过姓名不一定能找到这些,比如有重名的,通过性别也不能找到,通过专业号也不行,一个专业可以有很多学生在学习,通过年龄也不行,所以在上面这个关系模式中只有通过学号才能找到特定学生。

于是(学号,姓名)的组合属性集就称为超键。因为学号和姓名的组合能找到特定的学生。所以,在这个关系模式中

超键是:

(学号)、(学号,姓名、)(学号,性别)、(学号,专业编号)、(学号,年龄)、(学号,姓名,性别)、(学号,姓名,专业编号)、(学号,姓名,年龄)、(学号,姓名,性别,专业编号)、(学号,姓名,性别,年龄)、(学号,姓名,性别,专业编号,年龄)。

作用:

①保证实体的完整性

②加快数据库的操作速度

③在表中添加新记录时,表会自动检查新纪录的主键值,不允许该值与其他记录主键值重复

④表自动按主键值的顺序显示表中的记录,如果没有定义主键,则按输入记录的顺序显示表中的记录

2.候选键

是标识实体实例的最小属性 集合,可能包含一个或多个属性

不含多余属性的属性集(跟超键的区别)。比如按照上面给的例子(专业内学生姓名均不同):

学生(学号,姓名,性别,专业编号,年龄)

专业内学生姓名均不同,所以不仅仅通过学号能找到特定的学生,而且还能通过姓名找到特定的学生,性别、专业号、年龄这三个属性却不能找到特定的学生。

于是,学号和姓名就成了这个关系模式中的候选键,所以在这个关系模式中

候选键是:

(学号)、(姓名)

作用:

①保证实体的完整性

②加快数据库的操作速度

③在表中添加新记录时,表会自动检查新纪录的主键值,不允许该值与其他记录主键值重复

④表自动按主键值的顺序显示表中的记录,如果没有定义主键,则按输入记录的顺序显示表中的记录

3.主键

被选择为实体唯一标识符的候选键

在候选键中随意选取一个就可以成为主键,还是上面给的例子(专业内学生姓名均不同):

学生(学号,姓名,性别,专业编号,年龄)

主键是建立在候选键的基础上的,所以在上面候选键(学号)、(姓名)中随意选取其中一个即为主键

主键是:(学号)或者(姓名)

作用:

①保证实体的完整性

②加快数据库的操作速度

③在表中添加新记录时,表会自动检查新纪录的主键值,不允许该值与其他记录主键值重复

④表自动按主键值的顺序显示表中的记录,如果没有定义主键,则按输入记录的顺序显示表中的记录

http://www.lryc.cn/news/398014.html

相关文章:

  • Centos忘记密码,重置root密码
  • Android初学者书籍推荐
  • 安卓文件上传照片单张及多张照片上传实现
  • 小白学webgl合集-import.meta.url 和 new URL() bug
  • pico+unity3d开启彩色透视
  • python常用命令
  • 使用定时器消除抖动
  • IOS热门面试题一
  • 构建LangChain应用程序的示例代码:62、如何使用Oracle AI向量搜索和Langchain构建端到端的RAG(检索增强生成)pipeline
  • ffmpeg转换MP4为gif命令
  • kotlin Flow 学习指南 (三)最终篇
  • Memcached负载均衡:揭秘高效缓存分发策略
  • 【Python实战因果推断】31_双重差分2
  • ArcGIS中使用线快速构造成面的方法
  • Spring AOP的几种实现方式
  • 字节码编程bytebuddy之实现抽象类并并添加自定义注解
  • LLM-阿里云 DashVector + ModelScope 多模态向量化实时文本搜图实战总结
  • CentOS7安装部署git和gitlab
  • 《昇思25天学习打卡营第16天|基于MindNLP+MusicGen生成自己的个性化音乐》
  • 算法学习day10(贪心算法)
  • 卡尔曼滤波Kalman Filter零基础入门到实践(上部)
  • 力扣-dfs
  • keepalived高可用集群
  • 文献翻译与阅读《Integration Approaches for Heterogeneous Big Data: A Survey》
  • 应用最优化方法及MATLAB实现——第3章代码实现
  • django的增删改查,排序,分组等常用的ORM操作
  • Leetcode Java学习记录——树、二叉树、二叉搜索树
  • 华为HCIP Datacom H12-821 卷30
  • element el-table实现表格动态增加/删除/编辑表格行,带校验规则
  • QT调节屏幕亮度