设计数据库之概念模式: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…

0x01_实验课leetcode

题目总结 lc1979 给你一个整数数组 nums ,返回数组中最大数和最小数的 最大公约数 。 两个数的 最大公约数 是能够被两个数整除的最大正整数。 会求 gcd 就行 class Solution { public:int gcd(int a, int b){return b ? gcd(b, a % b) : a;}int findGCD(vector&…

29-中断管理

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

【sql】初识 where EXISTS

文章目录 概述1. select 简单示例2. update和DELETE参考 相关文章: 【sql】深入理解 mysql的EXISTS 语法 【sql】初识 where EXISTS 概述 where EXISTS (子查询)多对多中通过中间表查对方列表 1. select 简单示例 用户表A,小组…

hive语法树分析,判断 sql语句中有没有select *

pom依赖参考以下博文java 通过 IMetaStoreClient 取 hive 元数据信息-CSDN博客1 节点处理器类 import lombok.Getter; import org.apache.hadoop.hive.ql.lib.Dispatcher; import org.apache.hadoop.hive.ql.lib.Node; import org.apache.hadoop.hive.ql.parse.ASTNode; impor…

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

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

windows搭建Elasticsearch环境

windows搭建Elasticsearch环境 本章搭建Elasticsearch ik分词器插件 kibana三个环境.三个版本都是7.8.0 1.安装Elasticsearch 安装网址: https://www.elastic.co/cn/downloads/past-releases#elasticsearch 下载解压后直接进入bin目录,双击运行elasticsearch.…

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

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

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

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

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

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

Terraform实战(四)-资源打标签

1 腾讯云 1.1 tf配置 标签(Tag)是腾讯云提供的云资源管理工具,以键值对 key:values 的形式存在,用于关联您的大多数云资源,对于资源的分类、搜索和聚合十分有用。 在 Terraform 中,通过 Map 来定义一个资…

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…

解决mysql连接数据太多,“Too many connections“ 解决办法

解决mysql连接数据太多,"Too many connections" 解决办法 mysql出现Too many connections提示一般原因就是你网站连接数超过了你msyql配置的连接数据了,解决办法就是修改一下mysql配置文件中的max_connections参数或修改你程序连接直接及时处理.。 先搞清楚MySQL的…

一、typescript基础数据类型

1&#xff0c;布尔 let isDone:boolean false;2, 数字&#xff0c; 所有数字都是浮点数 let n:number 1;3,字符串 let name:string "mily", sex:string 女;4.数组 let arr1:number[] [1, 2, 3] let arr2:Array<number> [1, 2, 3]5,元祖&#xff0c; …

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

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

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

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