设计数据库之概念模式:E-R模型

Chapter3:设计数据库之概念模式:E-R模型

笔记来源:《漫画数据库》—科学出版社

设计数据库的步骤:
概念模式

概念模式(conceptual schema)是指将现实世界模型化的阶段进而,是确定数据库理论结构的阶段。
概念模式的设计是通过E-R模型把握现实世界,进而规范化表格来实现的。

内部模式

内部模式是从计算机内部看到的数据库,是确定数据库物理构造的阶段。
内部模式的设计通过设计数据库高速检索方法来实现。

外部模式

外部模式是从用户和应用的角度来观察的数据库。
外部模式的设计是通过设计应用程序所必要的数据来实现的。

3.1 分析现状:E-R模型

设计数据库前需要对现实状况进行分析,这时就需要ER模型
实体就是能够认知的现实世界的事物。例如:例如将水果出口至其他国家这件事,就可以将水果和出口国作为实体来考虑。

关系就是表示实体之间有着怎样的关联。例如:水果和出口国之间就是由水果卖给出口国,这时可以把销售作为关系来考虑

实体(Entity),关系(Relationship)两个概念来考虑现实世界的模型就是E-R模型

一对一的关系
一个出口国管理一个出口记录信息。

一对多的关系
一个公主多个仆人

多对多的关系
水果销往多个出口国。
出口国购买多种水果。

3.2 规范化表格


将销售报表制作成表格

因为报表一行有两个数值,这个表格还不能直接用于数据库,如果一行只有一个数值的表格就容易处理了,这时需要把一张表拆分成多张表(一行仅有一个数值)

最初表格(非范式)分割为多个表格得到第一范式

非范式

非范式是没有除去数据重复的表格。关系数据库中是不能使用这种表格来进行数据管理的。因此需要对其做分割表格的规范化工作。


拆分为橙色圈住的一张表和蓝色圈住的一张表

第一范式

第一范式:表中每一列的属性都不可再分.
比如地址这个属性,很显然它可以分为省、市、区、乡镇等等,根据你的实际需求,如果你需要获取用户所在省份的话,很显然如果你只设计一个地址属性,是不方便直接获取省份的。
–引自如何通俗理解第一、二、三范式?

第一范式将表格分割为单纯的二元表格,即一栏中只有一个项目,每一列都是不可分割的基本数据项。分割表格时除去了重复项目。—引自《漫画数据库》—科学出版社

分成日期、出口国编码、出口国名称的表格 (销售表)和 商品编码、商品名称、单价、数量的表格(销售明细表(第一范式2))报表编码在两张表格中均有

我们看看第一范式2是否可以正确管理商品

在销售明细表中,如果橙子还没有销售,但此时橙子又进来货了,这是进货而不是销售,所以不能向销售明细表中更新进货的数据,至此单单一张销售明细表还不能正确管理商品,我们需要将销售明细表再次拆分
商品表(第二范式1)中商品编码是主键、销售明细表(第二范式2)中报表编码+商品编码这个组合是主键

我们再来看看第一范式1是否可以正确管理商品

我们发现销售表满足第二范式要求,由于上面第一范式2已经拆分为第二范式1和2,所以我们将其称之为第二范式3

第二范式:表中每一列的属性都不可再分,且非主属性完全依赖于主属性.
–引自如何通俗理解第一、二、三范式?
主键的值可以确定其他列的值

第二范式(second normal form)是按照通过可识别数据的键来确定其他列值的原则分割表格。这样,通过主键确定其他列的数值
关系数据库中这种“通过某一列的值确定其他列的数值”的原则我们称之为函数依赖。
第二范式是根据主键和其他列之间的函数依赖关系分割表格的。—引自《漫画数据库》—科学出版社

如果某个国家现在没有进口我国的水果,但想将其作为未来潜在用户加入到表中,这时这个国家是不能放到销售表中的,我们将此第二范式3再次拆分,拆为销售表和出口国表

第三范式:表中每一列的属性都不可再分,且非主属性完全依赖于主属性,且每个非主属性都不传递函数依赖于主属性.
–引自如何通俗理解第一、二、三范式?
由主键唯一确定其他列的表格叫第三范式

第三范式是按照只能由主键确定其他列值的原则分割的表格
在关系数据库的函数依赖中,“通过某一列的值间接确定其他列的值”我们称之为传递依赖
第三范式是去除传递依赖而分割表格得到的
—引自《漫画数据库》—科学出版社

下图来自:第一范式,第二范式,第三范式,BCNF范式理解

最初的一个销售报表最终拆分为销售表、出口国表、销售明细表、商品表,四张满足第三范式的表格,主键的值确定,则其他列的值唯一确定。这个拆分过程是逐步剔除主键与非主键部分依赖和传递依赖关系的过程,使得各个表即使添加数据也不会出现不一致的数据等问题,也使得各表间的关系明确。


各个第三范式的表格间关系明确

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

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

相关文章

Ubuntu 安装 Carla仿真环境

1、系统要求 Ubuntu 16.04/18.04/20.04 CARLA 为 16.04 之前的 Ubuntu 版本提供支持。然而,Unreal Engine需要合适的编译器才能正常工作。 CARLA 服务器至少需要 6 GB GPU,但建议使用 8 GB。 2、安装NIVDIA驱动 BISO设置 开机F12,进入BIOS…

29-中断管理

中断管理 什么是中断管理? 用户可以自定义配置系统可管理的最高中断优先级的宏定义configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY(高四位有效),它是用于配置内核中的basepri 寄存器的,当 basepri 设置为某个值的时候…

org.springframework.boot:type=Admin,name=SpringApplication异常

javax.management.InstanceNotFoundException: org.springframework.boot:typeAdmin,nameSpringApplication 问题描述: IDEA 新建 SpringBoot 项目,启动时后台报错: javax.management.InstanceNotFoundException: org.springframework.boot…

基于springboot的牙科就诊管理系统

技术:springbootmysqlvue 一、系统背景 当前社会各行业领域竞争压力非常大,随着当前时代的信息化,科学化发展,让社会各行业领域都争相使用新的信息技术,对行业内的各种相关数据进行科学化,规范化管理。这样…

粤嵌6818开发板如何理解Linux文件IO?

一、文件IO的概述 1、什么是文件? Linux下一切皆文件。普通文件、目录文件、管道文件、套接字文件、链接文件、字符设备文件、块设备文件。 2、什么是IO? input output:输入输出 3、什么是文件IO? 对文件的输入输出,把…

轻松找回丢失数据EasyRecovery数据恢复软件让你无后顾之忧

轻松找回丢失数据,EasyRecovery数据恢复软件让你无后顾之忧,电脑数码行业必备工具,让你的数据安全有保障 ! 一、EasyRecovery数据恢复软件简介 在我们的日常生活中,无论是工作还是学习,都离不开电脑和数据…

Linux/Perfection

Enumeration nmap 用 nmap 扫描了常见的端口,发现对外开放了 22,80,扫描一下详细信息,如下所示 ┌──(kali㉿kali)-[~/vegetable/HTB/Perfection] └─$ nmap -sC -sV -p 22,80 10.10.11.253 -oA nmap Starting Nmap 7.93 ( https://nmap…

目标检测——DOTA航拍数据集

DOTA数据集是一个用于航空图像中目标检测的大规模数据集,旨在帮助研究人员开发和评估航空图像中的目标检测算法。该数据集具有广泛的应用价值,尤其在计算机视觉和遥感技术领域。 DOTA数据集的特点主要体现在以下几个方面:首先,其…

408学习笔记-14-C-数据在内存中的存储

1、整数型存储 整数型存储就是所有整型家族里的数据类型的存储方式,也就是说包含了字符类型的存储(因为字符的操作符的返回值是ASCII码值,故实际上存储的是整数)。 1.1、有符号整数 有符号整数包含char,short&#x…

如何做接口测试?

今天来聊聊接口测试,现在是2024年了,打开招聘网站随便点开一个招聘帖子,几乎都可以看到岗位JD要求写着有接口测试经验优先。其重要性可见一斑! 目前,凡是好一点稍具规模的公司哪怕是大厂外包也几乎都要求会接口测试&a…

QT(6.5) cmake构建C++编程,调用python

一、注意事项 explicit c中,一个参数的构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数),承担了两个角色,构造器、类型转换操作符, c提供关键字explicit,阻止转换构造函数进行的隐式转换的发生&#…

使用Docker搭建YesPlayMusic网易云音乐播放器并发布至公网访问

目录 ⛳️推荐 1. 安装Docker 2. 本地安装部署YesPlayMusic 3. 部署公有云YesPlayMusic播放器 3.1 安装cpolar内网穿透 3.2 固定YesPlayMusic公网地址 ⛳️推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一…

【区间、栈】算法例题

目录 六、区间 48. 汇总区间 ① 49. 合并区间 ② 50. 插入区间 ② 51. 用最少数量的箭引爆气球 ② 七、栈 52. 有效的括号 ① 53. 简化路径 ② 54. 最小栈 ② 55. 逆波兰表达式求值 ② √- 56. 基本计算器 ③ 六、区间 48. 汇总区间 ① 给定一个 无重复元素 的 …

LeetCode # 199. 二叉树的右视图

199. 二叉树的右视图 题目 给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。 示例 1: 输入: [1,2,3,null,5,null,4] 输出: [1,3,4] 示例 2: 输入: [1,null,3] 输出: [1,3] 示例 3…

大规模电商平台数据采集难点分析♫

▁▃▅▇主要包括以下几方面: API工具 ◆◆数据量巨大 任何系统,在不同的数据量面前,需要的技术难度都是完全不同的。 如果单纯是将数据采到,可能还比较好完成,但采集之后还需要处理,因为必须考虑数据的规…

如何根据业务需求选择合适的电子合同平台?

在数字化转型的浪潮中,电子合同已经成为企业运营中不可或缺的一部分。然而,面对市场上众多的电子合同平台,企业如何根据自身的业务需求做出合适的选择呢?本文将为您一一解答。 在电子合同的签署过程中,数字证书颁发机…

鸿蒙Harmony应用开发—ArkTS-全局UI方法(日历选择器弹窗)

点击日期弹出日历选择器弹窗,可选择弹窗内任意日期。 说明: 该组件从API Version 10开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 本模块功能依赖UI的执行上下文,不可在UI上下文不明确的地方使用&…

nodejs 常用命令

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,常用于服务器端编程。以下是一些 Node.js 的常用命令 1、安装 Node.js: 通常,你会从 Node.js 的官方网站下载并安装适合你操作系统的版本。安装完成后,你可以在命令行中…

跨域以及跨域配置

1、什么跨域 首先,在前后端没有分离项目,例如jsp、php,前后台代码没有实现物理上的分离。不存在跨域问题。前后端分离后,前后端的地址域名不同,而同源策略导致浏览器会拦截a地址访问b地址请求(a地址通过浏览…

【前端】Web Audio API接口介绍

简言 记录下Web Audio API接口的介绍。 Web Audio API 提供了在 Web 上控制音频的一个非常有效通用的系统,允许开发者来自选音频源,对音频添加特效,使音频可视化,添加空间效果(如平移),等等。 …