讲解DFD和ERD
DFD、ERD
- 1. DFD(数据流图,Data Flow Diagram)
- DFD的主要元素:
- DFD的层次结构:
- 举例:
- 1. 上下文图:
- 2. 分解图:
- DFD的应用:
- 2. ERD(实体关系图,Entity Relationship Diagram)
- ERD的主要元素:
- 举例:
- ERD的关系类型:
- ERD的应用:
- DFD与ERD的区别:
- 总结:
DFD(数据流图,Data Flow Diagram)和ERD(实体关系图,Entity Relationship Diagram)是两种常用于系统分析和设计的图形化工具。它们各自有不同的功能和应用场景。
1. DFD(数据流图,Data Flow Diagram)
数据流图(DFD)是系统分析和设计中常用的一种工具,用于描述系统中数据的流动和处理过程。DFD不仅能够反映系统的数据流动情况,还可以帮助分析系统各个模块的交互关系。
DFD的主要元素:
- 外部实体(External Entity):表示系统外部与系统交互的对象,如用户、外部系统等。外部实体可以是数据输入的源头或数据输出的目标。用矩形表示。
- 过程(Process):表示对数据进行处理的活动,通常是系统的一个功能模块。每个过程通常都有输入数据、输出数据和一个处理功能。用圆形或椭圆形表示。
- 数据流(Data Flow):表示数据在系统中的流动路径,用箭头表示,箭头的方向指示数据的流向。
- 数据存储(Data Store):表示数据在系统中的存储位置,例如数据库或文件。用平行线表示。
DFD的层次结构:
DFD通常分为不同的层次,以展示不同的细节:
- 上下文图(Context Diagram):是DFD的最高层次,它展示了整个系统与外部实体之间的交互。上下文图通常只有一个“过程”,这个过程代表整个系统。通过上下文图可以了解系统的边界和与外部实体的关系。
- 分解图(Decomposition Diagram):是对上下文图的进一步分解,它展示了系统内部各个子过程之间的数据流和处理。分解图的目的是将复杂的过程进一步细化,使系统设计更加清晰。
举例:
假设我们要设计一个简单的 学生管理系统,该系统包括了学生信息的录入和查询功能。
1. 上下文图:
在上下文图中,我们将整个系统看作一个单一的过程,与外部实体之间的交互如下所示:
- 外部实体:学生,管理员
- 系统的功能:学生信息的录入、查询、修改等。
+------------+ +-------------------+| 学生 |<------输入------>| 学生管理系统 || |----查询----->| |+------------+ +-------------------+↑ ↓+------------+ +-------------------+| 管理员 |<------输入------>| || |----查询----->| |+------------+ +-------------------+
在上下文图中,我们看到学生和管理员分别与“学生管理系统”进行数据交互。学生可以输入个人信息、查询自己的信息;管理员则输入学生信息、查询学生数据。
2. 分解图:
我们将“学生管理系统”这个单一过程进一步分解为多个子过程,例如“学生信息录入”、“学生信息查询”等。分解图如下:
+-------------------+
| 学生管理系统 |
+-------------------+/ \/ \
+------------+ +-------------------+
| 信息录入 | | 信息查询 |
+------------+ +-------------------+| |
+-----------+ +----------+
| 存储学生数据 | | 查找学生信息 |
+-----------+ +----------+
在这个分解图中,我们看到学生管理系统分为两个主要过程:
- 信息录入:处理学生信息的输入并存储到数据存储中。
- 信息查询:查询学生的个人信息。
DFD的应用:
- 分析需求:帮助理解数据如何在系统中流动,以及不同功能如何互相交互。
- 系统设计:确定系统的功能模块和数据流向,并为后续的开发提供依据。
2. ERD(实体关系图,Entity Relationship Diagram)
实体关系图(ERD)是一种用来表示数据实体及其之间关系的图形工具。在数据库设计中,ERD非常重要,它可以帮助设计合理的数据结构和数据库模式。
ERD的主要元素:
- 实体(Entity):表示现实世界中的事物或对象,通常是一个需要存储的数据对象。实体用矩形表示。例如,“学生”、“课程”。
- 属性(Attribute):表示实体的特征或性质,通常是实体的具体数据。属性用椭圆形表示,并与实体通过线连接。比如“学生”实体的属性有“学号”、“姓名”。
- 关系(Relationship):表示实体之间的联系。关系通常用菱形表示。例如,“学生”和“课程”之间可以有一个“选修”关系。
- 主键(Primary Key):唯一标识实体的属性。例如,“学号”可以是“学生”实体的主键。
- 外键(Foreign Key):在一个实体中引用另一个实体的主键,用于建立实体之间的关系。
举例:
假设我们要设计一个 学生选课系统,系统中的实体有“学生”和“课程”,它们之间有“选修”关系。ERD如下所示:
+------------+ 选修 +------------+
| 学生 |------------------| 课程 |
+------------+ +------------+
| 学号(PK) | | 课程号(PK) |
| 姓名 | | 课程名 |
+------------+ +------------+
在这个ERD中:
- 学生实体有两个属性:“学号”(主键)和“姓名”。
- 课程实体有两个属性:“课程号”(主键)和“课程名”。
- 选修是连接“学生”和“课程”的关系,表示一个学生可以选修多门课程。
ERD的关系类型:
- 一对一(1:1):例如,一个人有一个身份证。
- 一对多(1:N):例如,一个教师可以教授多门课程,但每门课程只能由一个教师教授。
- 多对多(M:N):例如,学生可以选修多门课程,每门课程也可以有多名学生选修。
ERD的应用:
- 数据库设计:帮助理解数据结构,并建立实体之间的关系模型。
- 数据规范化:确保数据冗余最小化,并优化数据库结构。
- 系统集成:帮助开发者理解数据如何在系统中流动,并指导数据库的实现。
DFD与ERD的区别:
- DFD:关注系统的“功能”与“数据流动”,重点描述如何处理和传输数据。
- ERD:关注系统中的“数据结构”和“实体关系”,重点描述数据库设计和数据模型。
总结:
- DFD帮助系统分析人员了解系统的数据流动和处理流程,适用于系统设计和需求分析阶段。
- ERD帮助数据库设计人员清晰地描述系统中的数据实体和它们之间的关系,适用于数据库设计和建模阶段。
相关文章:

讲解DFD和ERD
DFD、ERD 1. DFD(数据流图,Data Flow Diagram)DFD的主要元素:DFD的层次结构:举例:1. 上下文图:2. 分解图: DFD的应用: 2. ERD(实体关系图,Entity …...

TVM计算图分割--LayerGroup
文章目录 介绍Layergroup调研TVM中的LayergroupTVM Layergroup进一步优化MergeCompilerRegions处理菱形结构TVM中基于Pattern得到的子图TPUMLIR地平线的Layergroup介绍 Layergroup目前没找到严格、明确的定义,因为不同厂家的框架考虑的因素不同,但是基本逻辑是差不多的。一般…...

OPPO开源Diffusion多语言适配器—— MultilingualSD3-adapter 和 ChineseFLUX.1-adapter
MultilingualSD3-adapter 是为 SD3 量身定制的多语言适配器。 它源自 ECCV 2024 的一篇题为 PEA-Diffusion 的论文。ChineseFLUX.1-adapter是为Flux.1系列机型量身定制的多语言适配器,理论上继承了ByT5,可支持100多种语言,但在中文方面做了额…...

Spring 设计模式之责任链模式
Spring 设计模式之责任链模式 责任链模式用到的场景java举例 责任链模式 责任链模式(Chain of Responsibility)是一种行为设计模式,它允许你将请求沿着处理者链进行传递。 每个处理者可以对请求进行处理,也可以将请求传递给链中的…...

简单的 docker 部署ELK
简单的 docker 部署ELK 这是我的运维同事部署ELK的文档,我这里记录转载一下 服务规划 架构: Filebeat->kafka->logstash->ES kafka集群部署参照: kafka集群部署 部署服务程序路径/数据目录端口配置文件elasticsearch/data/elasticsearch9200/data/elas…...

四款主流的3D创作和游戏开发软件的核心特点和关系
四款主流的3D创作和游戏开发软件的核心特点和关系 3D建模软件: Blender: 开源免费,功能全面优点: 完全免费持续更新优化社区活跃,学习资源丰富功能全面(建模、动画、渲染等) 缺点: 学习曲线陡峭界面操作…...

聚划算!Transformer-LSTM、Transformer、CNN-LSTM、LSTM、CNN五模型多变量回归预测
聚划算!Transformer-LSTM、Transformer、CNN-LSTM、LSTM、CNN五模型多变量回归预测 目录 聚划算!Transformer-LSTM、Transformer、CNN-LSTM、LSTM、CNN五模型多变量回归预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 聚划算!Tran…...

信息安全工程师(76)网络安全应急响应技术原理与应用
前言 网络安全应急响应(Network Security Incident Response)是针对潜在或已发生的网络安全事件而采取的网络安全措施,旨在降低网络安全事件所造成的损失并迅速恢复受影响的系统和服务。 一、网络安全应急响应概述 定义:网络安全应…...

使用 OpenCV 实现图像的透视变换
概述 在计算机视觉领域,经常需要对图像进行各种几何变换,如旋转、缩放和平移等。其中,透视变换(Perspective Transformation)是一种非常重要的变换方式,它能够模拟三维空间中的视角变化,例如从…...

openGauss数据库-头歌实验1-4 数据库及表的创建
一、创建数据库 (一)任务描述 本关任务:创建指定数据库。 (二)相关知识 数据库其实就是可以存放大量数据的仓库,学习数据库我们就从创建一个数据库开始吧。 为了完成本关任务,你需要掌握&a…...

吉利极氪汽车嵌入式面试题及参考答案
inline 的作用 inline 是 C++ 中的一个关键字。它主要用于函数,目的是建议编译器将函数体插入到调用该函数的地方,而不是像普通函数调用那样进行跳转。 从性能角度来看,当一个函数被标记为 inline 后,在编译阶段,编译器可能会将函数的代码直接复制到调用它的位置。这样做…...

pycharm中的服务是什么?
在PyCharm中,服务是指允许在PyCharm中运行的一种功能或插件。服务可以是内置的,也可以是通过插件安装的。 一些常见的PyCharm服务包括: 调试服务:PyCharm提供了全功能的调试工具,可以帮助开发人员通过设置断点、监视变…...

[Unity Demo]从零开始制作空洞骑士Hollow Knight第十七集:制作第二个BOSS燥郁的毛里克
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、制作游戏第二个BOSS燥郁的毛里克 1.导入素材和制作相关动画1.5处理玩家受到战吼相关行为逻辑处理2.制作相应的行为控制和生命系统管理3.制作战斗场景和战斗…...

深度解析阿里的Sentinel
1、前言 这是《Spring Cloud 进阶》专栏的第五篇文章,这篇文章介绍一下阿里开源的流量防卫兵Sentinel,一款非常优秀的开源项目,经过近10年的双十一的考验,非常成熟的一款产品。 文章目录如下: 2、什么是sentinel&…...

Linux系统-日志轮询(logrotate)
作者介绍:简历上没有一个精通的运维工程师。希望大家多多关注作者,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。 这是Linux进阶部分的最后一大章。讲完这一章以后,我们Linux进阶部分讲完以后,我们的Linux操作部分就…...

机器学习在时间序列预测中的应用与实现——以电力负荷预测为例(附代码)
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 1. 引言 随着数据采集技术的发展,时间序列数据在各个领域中的应用越来越广泛。时间序列预测旨在基于过去的时间数据来…...

白杨SEO:百度在降低个人备案类网站搜索关键词排名和流量?怎样应对?【参考】
很久没有写百度或者网站这块内容了,一是因为做百度网站朋友越来越少,不管是个人还是企业;二是百度上用户搜索与百度给到网站的流量都越来越少。 为什么想到今天又来写这个呢?因为上个月有个朋友来咨询我说网站百度排名全没了&…...

前端实现json动画(附带示例)
前端实现json动画(附带示例) 使用lottie制作动画。1.json动画2.实现效果3.git仓库4.运行5.json动画天堂6.代码7. 经常使用的方法 使用lottie制作动画。 1.json动画 废话不多说,直接看效果图2.实现效果 3.git仓库 https://gitee.com/chaiach…...

AI 写作(一):开启创作新纪元(1/10)
一、AI 写作:重塑创作格局 在当今数字化高速发展的时代,AI 写作正以惊人的速度重塑着创作格局。AI 写作在现代社会中占据着举足轻重的地位,发挥着不可替代的作用。 随着信息的爆炸式增长,人们对于内容的需求日益旺盛。AI 写作能够…...

C#-类:索引器
索引器作用:可以让我们以中括号的形式访问自定义类中的元素。 规则自己定,访问时和数组一样 适用于,在类中有数组变量时使用,可以方便的访问、进行逻辑处理 可以重载,结构体也支持索引器 一:索引器的语法…...

Neo4j Cypher WHERE子句详解 - 初学者指南
Neo4j Cypher WHERE子句详解 - 初学者指南 前言1. WHERE子句基础1.1 WHERE子句的本质1.2 示例数据 2. 基本用法2.1 节点属性过滤2.2 关系属性过滤 3. 高级过滤技巧3.1 字符串匹配3.2 正则表达式3.3 属性存在性检查 4. 列表和范围操作4.1 IN操作符4.2 范围查询 5. 空值处理5.1 默…...

【CSS】标准怪异盒模型
概念 CSS 盒模型本质上是一个盒子,盒子包裹着HTML 元素,盒子由四个属性组成,从内到外分别是:content 内容、padding 内填充、border 边框、外边距 margin 盒模型的分类 W3C 盒子模型(标准盒模型) IE 盒子模型(怪异盒模型) 两种…...

栈详解
目录 栈栈的概念及结构栈的实现数组栈的实现数组栈功能的实现栈的初始化void STInit(ST* pst)初始化情况一初始化情况二 代码栈的插入void STPush(ST* pst, STDataType x)代码 栈的删除void STPop(ST* pst)代码 栈获取数据STDataType STTop(ST* pst)代码 判断栈是否为空bool ST…...

硬盘 <-> CPU, CPU <-> GPU 数据传输速度
1. 硬盘 <-> CPU 数据传输速度 import time import os# 定义文件大小和测试文件路径 file_size 1 * 1024 * 1024 * 100 # 100 MB 的文件大小 file_path "test_file.bin"# 创建一个测试文件并测量写入速度 def test_write_speed():data os.urandom(file_si…...

数据编排与ETL有什么关系?
数据编排作为近期比较有热度的一个话题,讨论度比较高,同时数据编排的出现也暗示着数字化进程的自动化发展。在谈及数据编排时,通常也会谈到ETL,这两个东西有相似点也有不同点。 数据编排和ETL(提取、转换、加载&#x…...

来了解一下!!!——React
React 是一个用于构建用户界面的 JavaScript 库,特别适合用于创建单页面应用程序(SPA)。它由 Facebook 维护,并且拥有一个活跃的社区,这使得 React 成为了目前最流行的前端框架之一。以下是关于 React 的一些重要信息和…...

用vite创建项目
一. vite vue2 1. 全局安装 create-vite npm install -g create-vite 2. 创建项目 进入你想要创建项目的文件夹下 打开 CMD 用 JavaScript create-vite my-vue2-project --template vue 若用 TypeScript 则 create-vite my-vue2-project --template vue-ts 这里的 …...

json-server的使用(根据json数据一键生成接口)
一.使用目的 在前端开发初期,后端 API 可能还未完成,json-server 可以快速创建模拟的 RESTful API,帮助前端开发者进行开发和测试。 二.安装 npm install json-server //局部安装npm i json-server -g //全局安装 三.使用教程 1.准备一…...

半波正弦信号的FFT变换
目录 Hello, 大家好,这一期我们谈谈半波正弦信号的FFT变化长什么样子。本文硬件使用GFARM02硬件模块[1],文章最后有其淘宝链接。核心器件为STM32F103RCT6,为Cortex-M3核,采用的CMSIS版本为CMSIS_5-5.6.0。 如图1所示&…...

Python数据分析NumPy和pandas(二十三、数据清洗与预处理之五:pandas的分类类型数据)
pandas的分类类型数据(Categorical Data) 这次学习使用Categorical Data,在某些 pandas 操作中使用分类类型能实现更好的性能和减少内存使用。另外还学习一些工具,这些工具有助于在统计和机器学习应用程序中使用分类数据。 一.背…...