五、需求分析建模之数据库建模

article/2025/9/12 4:46:31

1. 了解E-R图在基于数据库的软件系统分析中的作用。
2. 复习并深化理解E-R图的相关概念。
3. 学习从实际应用问题中抽取E-R模型的方法。
4. 掌握简单ER图模型建模工具


E-R模型 Entity-Relationship Model

E-R模型是一种数据建模的思想。

1. E-R模型的基本观点:
世界是由一组称作实体的基本对象和这些对象之间的联系构成的。

2. E-R模型的基本概念:

(1)实体:客观存在并可互相区分的事物,实体有类(实体,实体的型)和个体(实体的实例,实体的值)的概念。一类实体具有相同或相似的特性。

实体用属性来刻画

(2)属性:实体所具有的某一方面特征。

        实体:实体的型来刻画

         实体名称(属性名1,属性名2,…)→读者(借书证号,姓名,年龄,性别…)

        实例:实体的值来刻画

         实体名称(属性名1,属性名2,…)→读者(1,张三,25,男)读者(2,李四,22,女)

  属性的类型:

        单一属性与复合属性

              符合属性示例:家庭住址:省份,详细住址

              在关系模型中,复合属性一定要转化为单一属性(关系的第一范式)

        单值属性和多值属性

              多值属性示例:电话号码,一个人可以有多个电话号码

              在关系模型中,多值属性一定要转化为单值属性(关系的第一范式)

         可空属性和非空属性

               每个实例的该属性值可以是或不能是空值

         导出属性

               由其他属性计算而得,例如由出生年份可以得出年龄

(3)关键字/码:实体中能够用其值唯一区分开,这是特殊并关键的属性,每一实体都必须给出关键字

(4)联系:实体之间是有联系的,联系指一个实体的实例和其他实体实例之间可能发生的联系。联系是要表达的要素,无联系的实体是没有意义的。

参与发生联系的实体的数目,称为联系的度或元。联系有一元联系、二元联系(读者和图书)和多元联系(供货商,零件和工程项目)

实体是相对稳定的,但联系是多样化的。

一元联系:同一个实体中的实例之间的联系(部门1下设部门2,部门3)

角色(作用)实体在联系中的作用称为实体的角色,当同一实体的不同实例参与一个联系时,为区别各实例参与联系的方式,需要指明其角色
 

二元联系:一对一、一对多、多对多联系

联系的基数:实体实例之间的联系的数量,即一个实体的实例通过一个联系能与另一实体中相关联的实例的数目。

常见的映射基数:一对一(1:1),一对多(1:m),多对多(m:n)

完全参与联系,该端实例至少有一个参与到联系中,最小基数为1(1..m)不允许有空值

部分参与联系,该端实例可以不参与联系,最小基数为0(0..m)允许有空值


E-R模型的Chen方法图示化表达方法:



运用E-R模型建模的步骤

  1. 理解需求,寻找实体
  2. 用属性刻画每一个实体
  3. 确定每一个实体的关键字/码
  4. 分析实体之间的联系(数据建模的重点)
  5. 检查是否覆盖了需求

http://chatgpt.dhexx.cn/article/9rU3xlBo.shtml

相关文章

数据库设计(1)—需求分析

2019独角兽企业重金招聘Python工程师标准>>> 需求分析是设计数据库的起点,需求分析结果是否准确反映用户的实际要求将直接影响到后面各阶段的设计,并影响到设计结果是否合理实用。 一、需求分析的任务 需求的任务是通过详细调查现实世界要处理…

SQL数据库设计(一)---需求分析与逻辑设计

今天先来介绍 数据库设计中的需求分析和逻辑设计(ER图)阶段,明天介绍物理设计与维护优化,数据库设计是非常有意思的:-) 数据库设计 根据系统业务的需要,结合我们所选用的DBMS,为这个业务系统构建出最优的数据存储模型。 并建立好数据库中的表…

数据库设计2————需求分析

需求分析任务 1、信息需求。明确数据库需要存储的数据,对这些数据将哪些梳理,同时还要描述数据间的联系。 2、处理需求。定义系统数据处理的操作功能,描述操作的优先次序。包括操作的执行频率和场合,操作与数据间的联系&#xff…

数据库设计(一) 需求分析

目前,大多数的应用系统都属于数据库应用程序,都离不开数据库的支持。数据库设计方案的优劣对于应用程序的运行至关重要。数据库设计过程就是针对具体的应用环境,设计优化的逻辑模式,并根据所采用的数据库系统设计物理结构&#xf…

三、数据需求与数据库设计

数据需求与数据库设计 数据需求 项目中主要包含了用户、权限(菜单)、角色三种类型的数据,各种数据包含的数据项如下: (1)用户:用户名、密码、生日、头像、简介、用户类型 (2&…

SQL数据库实战需求分析→数据库设计

从这开始,就真正进入项目实战啦。先说点体会,我刚开始接触编程的时候,都是编写一些小东西,往往都是半天或者一天什么的就编完了,那时候根本没想过做程序之前还要有需求分析。经过快两年的学习,接触的都是比…

数据库性能需求分析及评估模型

数据库作为应用系统当中最重要的一块,也是性能测试非常关注的一块,根据我自己的项目经验,和以往对应用系统的性能需求分析和测试策略制定过程,总结一下如何开展数据库系统的性能需求分析,以及制定数据库能力评估模型。…

互联网应用开发实践:需求分析与数据库设计

在本文中将分析一个用于新生开学分配寝室的“宿舍秒杀”系统。从用户故事开始探索需求,进而分析得到系统的主要功能和非功能性需求。最后,根据需求分析设计数据库,数据库的设计原则是尽可能的方便之后的需求拓展和修改。 用户故事 用户故事一…

数据库应用系统的需求分析

一 需求分析的概念与意义 所谓的需求分析,就是对待开发系统要做什么,完成什么功能的全面描述 软件的一些特性使得需求的获取常常并不容易! 比如软件功能复杂,需求可变性,软件的不可见性 二 获取需求的方法 面谈实地…

数据库设计:需求分析

设计一个性能良好的数据库系统,明确应用环境对系统的要求是首要的和基本的。因此,应该把对用户需求的收集和分析作为数据库设计的第一步。 需求分析的主要任务是通过详细调查要处理的对象,包括某个组织、某个部门、某个企业的业务管理等&…

数据库设计 | 需求分析

一、需求分析要干一个什么样的事情? 通过详细调查现实世界要处理的对象(组织、部门、企业等), 充分了解原系统(手工系统或计算机系统)工作概况, 明确用户的各种需求,然后在此基础上确…

数据库设计之需求分析

需求分析简单地说就是分析用户的需求。根据分析是设计数据库的起点,需求分析结果是否准确反映用户的实际要求将直接影响到后面各阶段的设计,并影响到设计结果是否合理和实用。 1. 需求分析的任务 需求分析的任务是通过详细调查现实世界要处理的对象(组…

数据库技术-数据库需求分析、数据流概念

目录 需求分析 数据流 结构化分析案例-教材销购案例 例题讲解 每文一语 需求分析 1、需求分析的概念与意义 需求是指用户对软件的功能和性能的要求,就是用户希望软件能做什么事情,完成什么样的功能,达到什么性能。 需求分析是在计算机…

matlab gui 教学,新手入门教程(一)文本框和按钮的使用

matlab gui 教学,新手入门教程(一)文本框和按钮的使用 一、新建文件二、添加控件 一、新建文件 1、在MATLAB命令行中输入guide。 2、回车,进入GUI的界面,选择新建GUI–Blank GUI(Default)–浏览(自定义存储…

零基础入门MATLAB(一篇十分钟)

目录 一、复数 二、取整函数 三、无穷量(Inf)和非数值量(NaN) 四、逻辑类型 五、字符和字符串 六、函数句柄 七、结构体 八、数组类型 九、单元数组 十、map容器类型 参考《MATLAB R2020a 完全自学一本通》 一、复数 …

matlab如何使输出结果更美观(symdisp函数——pretty函数升级版)

matlab中有些计算结果比较长,直接查看有些困难,下面介绍pretty和symdisp函数优化输出结果,使结果更为直观。 演示示例1 有一个计算结果如下: >> f1f1 y^5 (- w - y0)*y^4 1800*y^3 (1498200*w - 1800*y0)*y^2 (3600*w…

Matlab中textscan函数用法

目录 语法 说明 示例 读取浮点数 读取不同类型的数据 删除字面文本 跳过每行的其余部分 指定分隔符和空值转换 指定要视为空或注释的文本 将重复的分隔符视为一个分隔符 指定重复的转换设定符并收集数值数据 读取或跳过引用文本和数值字段 读取外语日期 读取非默…

【MATLAB学习笔记01】【快速入门】初识MATLAB的界面和编辑脚本的基础知识

打开MATLAB后,建议各位新手,先随便按下各个按键,熟悉下总体的页面布局,并且对各个按键的功能有点印象,这样可以更容易上手。 主要功能区(下图用红色方框圈出来的位置): 命令行窗口…

零基础入门Matlab(一篇两个小时就能学完的入门博客)

目录 零基础入门matlab前言1.界面认识2.变量命名3.数据类型4.元胞数组和结构体5.矩阵操作6.程序结构7.基本绘图操作7.1.二维平面绘图7.2.三维立体绘图 8.图形的保存与导出9.补充 零基础入门matlab 前言 这篇文章很适合MATLAB的入门学习,这也是我在入门时学习的笔记…

MATLAB中text函数使用

目录 语法 说明 示例 向数据点添加文本说明 向多个数据点添加文本 显示多行文本 指定文本大小和颜色 修改现有文本 text函数的功能是向数据点添加文本说明。 语法 text(x,y,txt) text(x,y,z,txt) text(___,Name,Value) text(ax,___) t text(___) 说明 text(x,y,…