数据库设计入门:从需求分析到E-R图转换
创作时间:
作者:
@小白创作中心
数据库设计入门:从需求分析到E-R图转换
引用
CSDN
1.
https://blog.csdn.net/naozibuok/article/details/139530012
数据库设计是软件开发中的重要环节,它涉及到数据的组织、存储和管理。一个良好的数据库设计能够提高数据的完整性和一致性,同时优化数据访问的性能。本文将介绍数据库设计的基本步骤、E-R图转换为关系模式的方法以及E-R图的绘制方法。
数据库设计步骤
数据库设计通常包括以下几个阶段:
- 需求分析阶段:准确了解与分析用户需求。
- 概念结构设计阶段:通过对用户需求进行综合、归纳与抽象,形成一个独立于具体数据库管理系统的概念模型。
- 逻辑结构设计阶段:将概念结构转换为某个数据库管理系统所支持的数据模型,并对其进行优化。
- 物理结构设计阶段:为逻辑数据模型选取一个最适合应用环境的物理结构(包括存储结构和存取方法)。
- 数据库实施阶段:根据逻辑设计和物理设计的结果建立数据库,编写与调试应用程序,组织数据入库,并进行试运行。
- 数据库运行和维护阶段:数据库应用系统经过试运行后即可投入正式运行。在数据库系统运行过程中必须不断地对其进行评估、调整与修改。
E-R图转关系模式
实体之间的三类联系
实体之间的联系可以分为以下三类:
- 一对一(1:1)
- 一对多(1:n)
- 多对多(m:n)
E-R图转关系模式的方法
- E-R图需要满足的条件
- 实体之间通过关系相连。
- 实体-关系-实体之间有三类联系之一。
- 属性附属实体。
- 属性控制关系。
- 关系模式转E-R图的方法
- 若实体间联系是1:1,可以在两个实体类型转换成的两个关系模式中任意一个关系模式的属性中加入另一个关系模式的主键和联系类型的属性。
- 若实体间联系是1:n,则在n端实体类型转换成的关系模式中加入1端实体类型的主键和联系类型的属性。
- 若实体间联系是m:n,则将联系类型转换成关系模式,其属性为两端实体类型的键加上联系类型的属性,而主键为两端实体键的组合。
简单来说:
- 若实体间联系是1:1,则在任意一端关系模型中加入另一端的主键和关系的属性即可。
- 若实体间联系是1:n,则在n端关系模型中加入1端的主键和关系的属性。
- 若实体间联系是m:n,则把联系转换为关系模式,并且加入两端的主键组合为新的主键和关系的属性。
E-R图的画法
- 确定实体:识别系统中的所有实体,并用矩形表示每个实体。给每个实体命名,通常使用名词。
- 确定属性:列出每个实体的属性,并确定哪个属性作为每个实体的主键(唯一标识)。用椭圆形表示属性,并将其连接到对应的实体。
- 确定关系:识别实体间的所有逻辑联系,并用菱形表示这些关系。明确关系的类型(一对一、一对多、多对多)并通过线段将关系连接到相关的实体。
- 添加属性到关系:如果关系本身具有属性,也需要将这些属性添加到关系上,使用椭圆形表示,并连接到对应的菱形。
参考资料
- 王珊 萨师煊. 数据库系统概论(第5版). 高等教育出版社. 2014
- 数据库大题十五分钟速成(E-R图转换成关系模式)(适用于2022级太原理工大学软件学院)_哔哩哔哩_bilibili
热门推荐
哈尔滨医保的缴纳方式有哪些?这些缴纳方式的特点是什么?
家族办公室是干什么的,家族办公室和家族信托的区别
扬州自由行:如何合理安排行程
解码郑州:1300万人口城市的吸引力密码
解读宇宙文明等级,最高等级的宇宙文明超乎想象!
何你的猫咪爱互舔毛?背后原因竟然这么暖心!
注意了!高温带来的影响,远比你想象的要大
财务开票流程制度:企业财税合规与风险防控的法律要点
数说《哪吒2》的票房火爆,中国电影崛起进行时!
重复接地、保护接地、保护接零、工作接地、防雷接地、屏蔽接地、防静电接地的区别
农产品标准化与品牌建设:提升我国农产品竞争力的关键策略
《GTA 6》发布日期存变数 分析称可能推迟至2026年
防震减灾知识科普丨应急避震有方法
Excel中刷新随机数据的多种方法
断桥铝门窗国家标准(2024最新)
国考人力资源怎么选岗位
绿色供应链管理:推动企业可持续发展新路径
数字供应链:重塑企业供应链新篇章
淋巴结T细胞基因编辑:香港城市大学史鹏团队为癌症免疫治疗带来新希望
毛坯房物业费有何规定?
康复必看 | 从解剖到治疗,全方位了解腰椎管狭窄!
脚踇趾外翻很难看,要不要治疗?
手机怎么激活5G网络
好消息!中科院研发超低温特种锂离子电池,零下60℃仍能稳定工作
B站循环播放算播放量吗?深度解析背后规则与逻辑
电子屏幕看得久,眼睛不适怎么办 | 呵护眼健康
长期使用电脑的危害——警惕电子世界的副作用
避免伤“心”饮食,呵护心脏健康
离婚诉讼地点全解析:工作地、异地、网上能否办理?
中国各朝历代女子服饰特点