讲解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#-类:索引器
索引器作用:可以让我们以中括号的形式访问自定义类中的元素。 规则自己定,访问时和数组一样 适用于,在类中有数组变量时使用,可以方便的访问、进行逻辑处理 可以重载,结构体也支持索引器 一:索引器的语法…...
[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?
🧠 智能合约中的数据是如何在区块链中保持一致的? 为什么所有区块链节点都能得出相同结果?合约调用这么复杂,状态真能保持一致吗?本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里…...
挑战杯推荐项目
“人工智能”创意赛 - 智能艺术创作助手:借助大模型技术,开发能根据用户输入的主题、风格等要求,生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用,帮助艺术家和创意爱好者激发创意、提高创作效率。 - 个性化梦境…...

多模态2025:技术路线“神仙打架”,视频生成冲上云霄
文|魏琳华 编|王一粟 一场大会,聚集了中国多模态大模型的“半壁江山”。 智源大会2025为期两天的论坛中,汇集了学界、创业公司和大厂等三方的热门选手,关于多模态的集中讨论达到了前所未有的热度。其中,…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
Frozen-Flask :将 Flask 应用“冻结”为静态文件
Frozen-Flask 是一个用于将 Flask 应用“冻结”为静态文件的 Python 扩展。它的核心用途是:将一个 Flask Web 应用生成成纯静态 HTML 文件,从而可以部署到静态网站托管服务上,如 GitHub Pages、Netlify 或任何支持静态文件的网站服务器。 &am…...

如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
sqlserver 根据指定字符 解析拼接字符串
DECLARE LotNo NVARCHAR(50)A,B,C DECLARE xml XML ( SELECT <x> REPLACE(LotNo, ,, </x><x>) </x> ) DECLARE ErrorCode NVARCHAR(50) -- 提取 XML 中的值 SELECT value x.value(., VARCHAR(MAX))…...
工业自动化时代的精准装配革新:迁移科技3D视觉系统如何重塑机器人定位装配
AI3D视觉的工业赋能者 迁移科技成立于2017年,作为行业领先的3D工业相机及视觉系统供应商,累计完成数亿元融资。其核心技术覆盖硬件设计、算法优化及软件集成,通过稳定、易用、高回报的AI3D视觉系统,为汽车、新能源、金属制造等行…...

select、poll、epoll 与 Reactor 模式
在高并发网络编程领域,高效处理大量连接和 I/O 事件是系统性能的关键。select、poll、epoll 作为 I/O 多路复用技术的代表,以及基于它们实现的 Reactor 模式,为开发者提供了强大的工具。本文将深入探讨这些技术的底层原理、优缺点。 一、I…...

如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...