数据库范式1NF-4NF

码和属性

字段是对内而言的,private
属性是对外而言的,public
用Java中的类比喻就是一个对像里面定义了很多字段,一般情况下每个字段都有一组对应的getter&setter方法,注意到了吗,字段一般用private修饰,而它的getter&setter方法却是用public修饰!而且字段和它对应的getter&setter方法名称是对应的,这个时候我们可以认为字段 = 属性
但是如果我另外写一个getX方法,它是把对象中的两个字段nameid拼在一起返回,这个时候就不能说字段 = 属性了,因为X不对应任何一个单独的字段,它包含nameid两个字段,是作为一个独立的属性存在的!

码:具有唯一性的key;
候选码(Candidate key):

  • 若关系中的某一属性组的值能唯一地标识一个元组(一行数据),则称该属性组为候选码;
  • 在最简单的情况下,候选码只包含一个属性;
  • 在最极端的情况下,关系模式的所有属性组是这个关系模式的候选码,称为全码(AIl-key);

主码:若一个关系有多个候选码,则选定其中一个为主码(Primary key),也就是主键;
主属性:候选码的诸属性称为主属性(Primeattribute);
非码属性:不包含在任何侯选码中的属性称为非码属性(Non-key attribute);
超码:也叫超键,是指包含所有候选键属性及其他非码属性的集合;

第一范式(1NF)

  • 数据库中:表的每一列都是不可分割的基本数据项,同一列中不能有多个值(不能是集合、数组等)
  • 实体中:某个属性不能有多个值,或者不能有重复的属性,即每个属性都是不可分割的原子项。

下面例子中,属性 课程编号 存储的是一个可以再分割的集合,非原子项,违背了第一范式;
在这里插入图片描述

第二范式(2NF)

在1NF基础上,一个关系(表)必须有一个主键(主码),且非主属性(非主码属性)必须完全依赖于主键(主码)。

例一

在这里插入图片描述
在这个关系(表)中
主码(主键)X = {货物类型,货物ID},包含了主属性货物类型和主属性货物ID
Y、Z都是非主属性(也是非码属性)
现在的关系是通过主码X确定YZ

但是现在存在的问题是:Z其实只和X中的货物类型这个字段有关,也就是Z只依赖部分X;
说人话就是Z只需要X的一部分就能确定下来,而不用X的完整体才能确定;
这就不满足2NF,所以接下来拆分成两个表:
在这里插入图片描述
在这里插入图片描述
这样拆分后,形成了一下关系:
表一:X{货物类型,货物ID} → Y{货物名称},即Y完全依赖X才能确定
表二:X{货物类型)}→ Z{注意事项},即Z完全依赖X才能确定
这样就满足了第二范式

例二

在这里插入图片描述
在这个表中,主键(主属性)是{学生学号,课程编号},由两个字段组成
为什么主键不是{学生学号}?
因为单凭{学生学号}定位不了{成绩}这个属性;
也就是说{成绩}完全依赖于主属性{学生学号,课程编号};
再看{学生姓名}{班级}{院系}这三个非主属性,只需要{学生学号}就能确定,也就是只依赖部分主属性,因此这个表(关系)也不符合2NF;
于是,把这个关系拆分:
在这里插入图片描述
在这里插入图片描述
好了,这下ojbk了
表一:非主属性{学生姓名}{班级}{院系}完全依赖主属性{学生学号}
表二:非主属性{成绩}完全依赖主属性{学生学号,课程编号}
完美

第三范式(3NF)

在2NF基础上,任何非主属性不依赖于其它非主属性(在2NF基础上消除传递依赖)

在这里插入图片描述
比如在这个关系中,非主属性U完全依赖于非主属性Z,不符合3NF。
所以也应该进行拆分,把非主属性Z、U单独建表

巴斯科德范式(BCNF)

巴斯-科德范式即在满足3NF基础上,任何主属性不能对候选码子集有依赖(即在3NF基础上,消除主属性对候选码的部分函数依赖和传递函数依赖)

BCNF既检查非主属性(同第三范式),又检查主属性(与3NF的不同之处)。
满足BCNF范式的关系都必然满足第三范式。

换个方式说,若一个关系达到了第三范式,并且它只有一个候选码,或者它的侯选码都是单属性,则该关系自然达到BCNF。一般来说,一个数据库设计符合3NF或BCNF就可以了。

第四范式

消除表中的多值依赖,要求把同一表内的多对多关系删除;
分解表格,以解决信息冗余,达到“一事一地”也就是一对一的关系;
例:
在这里插入图片描述
在这个表中,球队城市和主教练都依赖于球队,这就是多值依赖,多个属性(无论是不是主属性)依赖于同一个主属性;
所以拆分成两张表:球队 → 球队城市,球队 → 主教练 ,达到一对一的要求

总结

1NF:使属性具有原子性;
2NF:消除非主属性对主键(主码)的部分依赖;
3NF:消除非主属性对主建(主码)的传递依赖;
BCNF:消除主属性对主键(主码)的部分依赖;
4NF:消除属性间的多值依赖;

参加资料:

  1. 【数据库范式讲解(从1Nf到4NF)】 https://www.bilibili.com/video/BV1iU4y157JG/?share_source=copy_web&vd_source=e22a75a6781804ee25ce46a2afc235ce
  2. 【320-数据库范式之第二范式讲解】 https://www.bilibili.com/video/BV19y4y1v7sy/?share_source=copy_web&vd_source=e22a75a6781804ee25ce46a2afc235ce
  3. 【321-数据库范式之第三范式讲解】 https://www.bilibili.com/video/BV1eX4y1u7CR/?share_source=copy_web&vd_source=e22a75a6781804ee25ce46a2afc235ce
  4. 【第一范式到第四范式的拆表拆表再拆表】 https://www.bilibili.com/video/BV1YV411s7iV/?share_source=copy_web&vd_source=e22a75a6781804ee25ce46a2afc235ce
  5. 【快速掌握数据库主码候选码主属性】 https://www.bilibili.com/video/BV1xD4y147Ma/?share_source=copy_web&vd_source=e22a75a6781804ee25ce46a2afc235ce
  6. 【【数据库设计】学习数据库键(Key)-:主键、外键、候选键、替代键等等】 https://www.bilibili.com/video/BV1ym4y1L7Lh/?share_source=copy_web&vd_source=e22a75a6781804ee25ce46a2afc235ce

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/188658.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOs 4 (一) 认识HarmonyOs

目录 一 HarmonyOs 背景1.1 发展时间线1.2 背景分析1.2.1 新场景1.2.2 新挑战1.2.3 鸿蒙生态迎接挑战 二 HarmonyOS简介2.1 OpenHarmony2.2 HarmonyOS Connect2.3 HarmonyOS Next**2.4 ArkTS (重点掌握)****2.5 ArkUI** 三 鸿蒙生态应用核心技术理念**3.…

探索APP自动化测试工具的重要作用是什么?

随着移动应用市场的蓬勃发展,保障应用程序的质量和性能成为开发团队至关重要的任务。在这个背景下,APP自动化测试工具崭露头角,成为提高开发效率、减少错误率的关键工具。本文将探讨APP自动化测试工具的用途,以及它们在移动应用开…

mongoDB非关系型数据库学习记录

一、简介 1.1Mongodb是什么 MongoDB是一个基于分布式文件存储的数据库,官方地址https://www.mongodb.com/ 1.2数据库是什么 数据库(DataBase)是按照数据结构来组织、存储和管理数据的应用程序 1.3数据库的作用 数据库的主要作用就是管理数据,对数据进行增©、删(d)、…

大语言模型(LLMs)在 Amazon SageMaker 上的动手实践(一)

本期文章,我们将通过三个动手实验从浅到深地解读和演示大语言模型(LLMs),如何结合 Amazon SageMaker 的模型部署、模型编译优化、模型分布式训练等。 实验一:使用 Amazon SageMaker 构建基于开源 GPT-J 模型的对话机器…

C语言错误处理之 “strerror和perror函数以及断言处理方式”

目录 前言 perror函数 strerror函数 断言处理方式 前言 在错误处理一中,我们解释了C语言三种处理方式中的错误号处理方式,这一篇我们在基于上一篇的基础上加入了strerror函数与perror函数,以及断言处理方式的内容...... perror函数 包…

VSCode下载安装教程+安装插件

一、vscode下载安装 1.打开 官网:https://code.visualstudio.com/Download 2.选择跟你电脑相对应的版本下载,我是win10,所以选择如下: 3.下载到你想要保存的目录下 4.下载完成后打开目录,双击安装包 5. 同意&#xff…

使用YOLOv8训练自己的数据集

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 | 接辅导、项目定制 拉取项目 git clone https://github.com/ultralytics/ultralytics安装依赖 cd ultralytics pip install -r requirement.txt pip instal…

【android开发-10】android中四种布局详细介绍

在Android开发中,常见的四种布局分别是:线性布局(LinearLayout)、相对布局(RelativeLayout)、帧布局(FrameLayout)和绝对布局(AbsoluteLayout)。 注意&#…

第16届中国R会议暨2023X-AGI大会开幕,和鲸科技分享ModelOps在数据科学平台中的实践与应用

11月25日,第 16 届中国 R 会议暨 2023 X-AGI 大会在在中国人民大学逸夫会堂拉开帷幕,本次会议由中国人民大学统计学院、中国人民大学应用统计科学研究中心、统计之都、原灵科技和中国商业统计学会人工智能分会(筹)主办&#xff0c…

React项目使用NProgress作为加载进度条

React项目使用NProgress作为加载进度条 0、效果1、react安装依赖2、使用3.进度条颜色设置 文档参考:https://zhuanlan.zhihu.com/p/616245086?utm_id0 0、效果 如下,可全局在页面顶部有一条进度条 1、react安装依赖 yarn add nprogress通过以上安装…

pytest自动化框架之allure测试报告的用例描述设置

allure测试报告的用例描述相关方法;如下图 allure标记用例级别severity 在做自动化测试的过程中,测试用例越来越多的时候,如果执行一轮测试发现了几个测试不通过,我们也希望能快速统计出缺陷的等级。 pytest结合allure框架可以对…

YOLOv5项目实战(5)— 算法模型优化和服务器部署

前言:Hello大家好,我是小哥谈。近期,作者所负责项目中的算法模型检测存在很多误报情况,为了减少这种误报情况,作者一直在不断优化算法模型。鉴于此,本节课就给大家详细介绍一下实际工作场景中如何去优化算法模型和进行部署,另外为了方便大家进行模型训练,作者在文章中提…

oracle FUNCTION(任意两个时间 之间的工作小时)

写函数计算 任意两个时间 之间的工作小时 每天工作时间(8:00 - 20:00 共12小时),没有休息日 CREATE OR REPLACE FUNCTION SC_YD_DESI.CALCULATE_WORK_HOURS_FUNC (p_current_time IN DATE,p_order_time IN DATE ) RETURN NUMBER ASp_work_hou…

AWS Remote Control ( Wi-Fi ) on i.MX RT1060 EVK - 1 “建立开发环境”

这个系列的文章将叙述如何借由 NXP 的“evkmimxrt1060_aws_remote_control_wifi_nxp”这支 Sample Code,达到 NXP RT1060EVK 经由 U-Blox EVK-JODY-W263 将资讯传到 AWS 上,并可借由手机对 RT1060 EVK 的 LED 进行远端控制。 整体架构如下图所示&#x…

道可云会展元宇宙平台全新升级,打造3D沉浸式展会新模式

随着VR虚拟现实、人工智能、虚拟数字人等元宇宙技术的快速发展,各个行业正试图通过元宇宙技术寻求新的发展突破口,会展行业也不例外。会展作为经贸领域的重要产业形态,越来越多的企业和组织开始寻求通过元宇宙技术为展会赋能,以满…

【EI会议征稿】第七届大数据与应用统计国际学术研讨会(ISBDAS 2024)

第七届大数据与应用统计国际学术研讨会(ISBDAS 2024) 2024 7th International Symposium on Big Data and Applied Statistics 第七届大数据与应用统计国际学术研讨会(ISBDAS 2024)定于2024年3月8-10日在中国上海举行。会议旨在…

最小化安装 Neokylin7.0 用于搭建 Hadoop 集群

文章目录 环境搭建背景虚拟机创建和环境配置安装过程注意事项虚拟机设置软件选择KOUMP系统分区网络和主机名打开以太网,并记录信息配置 IPv4修改主机名 创建用户 hadoop完全分布式搭建-CSDN博客 环境搭建背景 为什么不从hadoop100或者hadoop101开始,而是…

STM32CubeMx+MATLAB Simulink点灯程序

STM32CubeMxMATLAB点灯程序 ✨要想实现在MATLAB Simulink环境下使用STM32,前提是已经搭建好MATLAB环境并且安装了必要的Simulink插件,以及对应的STM32支持包。 🌿需要准备一块所安装支持包支持的STM32开发板. 🔖具体支持包详情页…

Java强制类型转换的所有规则都在这里了

💗推荐阅读文章💗 🌸JavaSE系列🌸👉1️⃣《JavaSE系列教程》🌺MySQL系列🌺👉2️⃣《MySQL系列教程》🍀JavaWeb系列🍀👉3️⃣《JavaWeb系列教程》…

VR全景对旅游业有什么帮助,如何助力旅游业实现新的旅游形式

引言: 旅游业是一个充满机遇的行业,而虚拟现实(VR)全景技术正逐渐改变着旅游业的面貌,通过提供身临其境的体验,VR全景成为了旅游业的新宠,将旅游带入了一个全新的数字化时代。 一、打破地域限制…