数据库逻辑结构设计-实体和实体间联系的转换、关系模式的优化

一、引言

如何将数据库概念结构设计的结果,即用E-R模型表示的概念模型转化为关系数据库模式。

E-R模型由实体、属性以及实体间的联系三个要素组成 

将E-R模型转换为关系数据库模式,实际上就是要将实体及实体联系转换为相应的关系模式,转换应遵循相应的规则,并确定这些关系模式的主键及外键,利用外键来体现实体间的联系。最后,还要对转换后的关系模式进行优化

二、实体的转换 

1、转换的规则是一个实体要单独转换为一个关系模式。实体的属性就是关系的属性,实体的关键字就是关系的主键。

2、举例:例如将一个学生实体转换为一个学生关系模式

(1)关系名为学生,包含学号、姓名、性别属性,学号为主键、

三、实体间联系的转换

1、根据实体间联系的类型,联系可单独转换为一个关系模式,也可不单独转换为一个关系模式

2、在转换后的关系模式中,应体现实体间的联系以及联系本身的属性

3、1:1联系的转换

假设班长被抽象为实体,而不是班级的属性,则班长和班级之间具有1:1的联系。对于1:1的联系,既可单独对应一关系模式,也可以不单独对应一关系模式

(1)若将该联系单独转换为一个关系模式

  • 该关系的属性则由参与联系的各实体的关键字以及该联系本身的属性构成
  • 每个实体的关键字均可作为该关系的主键
  • 每个实体的关键字均为该关系模式的外键

则班级和班长之间1:1的联系可转换为一个关系模式,可命名为负责人,具有班级号和学号两个属性,均可作为该关系的主键,均为该关系的外键,分别对应班级关系的主键班级号和班长关系的主键学号

(2)如果联系不对应一关系模式

  • 可将联系合并到与该联系相关的任意一端实体所对应的关系模式中,需要再被合并的关系模式中,增加联系本身的属性以及与联系相关的另一实体的关键字 
  • 新增属性后,原关系模式的主键不变
  • 增加的另一端实体的关键字为该关系模式的外键

对于班长和班级之间的1:1联系,则可在班级关系模式,增加一个班长学号属性 ,应是外键,对应班长关系的主键学号,主键仍是班级号

或在班长的关系模式中,增加一个班级号属性,应是外键,对应班级关系的主键班级号,主键仍为学号 

(3)这里给出 E-R模型中的1:1联系转换规则的抽象表达

对于实体E1和E2间的1:1联系,可以有三种转换处理方法

4、在教学信息管理案例系统中,班级和学生之间具有1:n的属于联系 ,对于1:n的联系,既可以单独对应一关系模式,也可以不单独对应一关系模式

(1)若将该联系单独转换为一个关系模式

  • 该关系模式的属性则由参与联系的各实体的关键字以及该联系本身的属性构成
  • 且该关系的主键为N端实体的关键字
  • 每个实体的关键字均为该关系模式的外键

班级和学生之间的1:n的联系可以转换为一个关系模式,命名为属于,具有学号和班级号两个属性,均为该关系的外键,分别对应学生关系的主键学号和班级关系的主键班级号,学生实体的关键字学号作为该关系的主键

(2)如果联系不单独对应一关系模式

  • 可将联系合并到n段实体所对应的关系模式中,需要在n端实体对应的关系模式中增加联系本身的属性以及1端实体的关键字
  • 新增属性后,关系模式的主键不变,仍为原关系模式的主键
  • 1端实体的关键字应是该关系模式的外键

对于班级和学生之间1:n的联系,则可在学生关系中增加一个所在班级号属性作为外键,对应班级关系的主键班级号,主键仍为学号

这里给出1:n联系转换规则的抽象表达,对于实体E1与E2之间的1:n联系,可以有两种转换处理方法

 5、在教学信息管理案例系统中 ,学生和课程之间具有m:n的选课联系,对于这类m:n的联系,只能转换为一个独立的关系模式

  •  该关系模式的属性由参与联系的各实体的关键字以及该联系本身的属性构成
  • 关系模式的主键各实体的关键字属性组合
  • 每个实体的关键字均为该关系模式的外键

学生和课程之间m:n的联系要转换为一个单独的关系模式可命名为选课成绩,具有学号、课程号和成绩三个属性,学号和课程号组合构成该关系的主键,又均为该关系的外键,分别对应学生关系的主键学号和课程关系的主键课程号

这里给出m:n联系转换规则的抽象表达,实体E1和E2之间的m:n的联系,只能有一种转换处理方法 

6、对于三个或三个以上实体多对多联系的转换,可根据情况采用不同的处理方法

  • 若只有一个多端实体,则可按1:n联系的转换规则进行转换,可单独转换为一个关系模式,也可不单独转换为一个关系模式。将与联系相关的实体的关键字以及联系本身的属性作为新属性加入到多端实体所对应的关系模式中 
  • 若有多个多端实体,则按m:n联系的转换规则进行转换,需转换为一个单独的关系模式。该关系模式的属性为多元联系相连的各实体的关键字以及联系本身的属性,而关系模式的主键各实体的关键字的组合

对于班级、课程和教师三个实体间,多对多联系可单独转换为一个关系模式,命名为班级选课,包含班级号、课程号、教师编号、上课年度、上课学期等属性,班级号、课程号、教师编号组合构成该关系的主键,又均为该关系的外键,分别对应三个实体关系的主键

四、子实体与ISA联系的转换

 对于研究生这类子实体及与超类实体学生间的ISA联系,应该如何转换

  • 子实体应单独转换为一个关系模式,关系模式的属性由超类实体的关键字和子类实体本身的属性构成
  • 超类实体的关键字作为关系的主键,也是参照超类实体关系的外键可通过外键继承超类实体的所有属性和与超类实体相关的联系 

对于学生的一个子实体集研究生,可单独转换为一个关系模式,包括学号、所在学科、研究方向等属性,主键为学号,学号也是关系的外键,对应学生关系的主键学号

 

五、弱实体与依赖关系的转换

对于可能存在的家庭成员这类依赖于常规实体的弱实体及依赖关系应该如何转换呢?

因弱实体不能独立存在,且弱实体和常规实体之间只能是1:1或n:1联系

  • 所以应将弱实体单独转换为一个关系模式,关系模式的属性常规实体的关键字弱实体本身的属性构成 
  • 关系模式的主键由常规实体的关键字与弱实体的关键字组合构成,说明弱实体要依赖于常规实体而不能单独存在
  • 常规实体的关键字作为外键,来体现两个实体间的联系

对依赖于学生实体的家庭成员弱实体需单独转换为一个关系模式,包括学生学号,家庭成员的身份证号、姓名 ,与学生的关系,职业、住址等。学号和家庭成员的身份证号组合构成家庭成员关系的主键,学生学号作为关系的外键,对应学生实体关系的主键学号

六、案例系统

针对教学信息管理信息案例系统的数据库概念结构设计所得的E-R图,利用前述的实体与联系转换规则,可得到该数据库的逻辑结构设计结果,即数据库关系模式

1、包含实体对应的关系,有班级、教研室、课程关系

2、体现1:n联系的实体关系,有学生关系和教师关系

3、体现m:n联系的联系关系,有班级选课和选课成绩关系

 4、子实体关系有研究生关系和导师关系

在研究生关系中增加属性指导教师,体现了与导师的多对一联系 

 在每个体现联系的关系模式中,都确定了与参照关系的外键

七、逻辑结构设计原则

  • 从转换结果可以看出,按转换规则将概念结构设计的E-R图中的实体和联系转换为关系模式,遵循的是“一事一地”的模式设计原则。
  • 所得到的关系数据库模式中,每个关系描述的信息比较单一,仅描述一个概念,即一个实体或实体之间的一种联系

八、关系模式的优化

(一)在数据库逻辑结构设计阶段,完成前面的逻辑结构设计后,还需要根据应用需求,对关系数据库模式进行优化。关系模式的优化是为了进一步数据库应用系统的性能,根据应用需求适当修改、调整关系模式的结构

  • 一种优化就是以关系规范化理论为指导,根据范式要求,将关系模式规范化为3NF或BCNF
  • 如果数据库设计者能深入分析应用需求正确抽取所有的实体和联系,并将其由E-R模型按规则正确转换为关系模式,则关系模式通常不需要进行过多的规范化

1、比如对于学生实体和课程实体及两个实体间m:n的选课联系,按转换规则转换为三个关系模式,可判断每个关系模式均满足BCNF。但如果不按转换规则来转换,把m:n的联系不单独转换为一个关系模式,像1:n联系一样,把学生的学号和联系的成绩属性加入到课程实体中,主键也是学号和课程号组合,可判断此时课程关系只满足1NF。

2、但对于由班级选修教师所授课程联系转换来的班级选课选课关系模式,相关的需求分析的描述是

  • 每个班级选修本专业开设的若干门课程,一个班级选修的某门课程只能由同一个教师来讲授。由该需求描述,可确定班级号和课程号函数决定教师编号
  • 由相同课程可由不同教师讲授的需求描述,可确定课程号不函数决定教师编号
  • 一个教师可为同一个班级讲授不同的课程,或为不同的班级讲授相同的课程,由该需求描述可确定班级号和教师编号不函数决定课程号,课程号和教师编号也不函数决定班级号
  • 班级选修的某门课程只能在一个年度内的一个学期内实施完成。由该需求描述,可确定班级号和课程号函数决定上课年度和上课学期

 

 

由以上这些函数依赖,可判断班级号和课程号,完全函数决定关系的所有其他属性,可做主键。因此我们可修改班级选课关系(讲授关系)的关系模式设计,将主键改为班级号和课程号的集合。可以看到,原来以班级号、课程号和教师编号为主键的班级选课关系存在着非主属性对于候选键的部分函数依赖,关系模式只满足1NF,经过这样的修改,关系模式可达到BCNF,使得在授课教师没有确定的情况下,可进行学生教学计划的信息插入等操作。

需要注意的是,这里范式级别的提高,不是通过模式分解来完成的,而是通过修改关系模式的主键来消除部分函数依赖来实现的

(二)关系模式的另一种优化,是为满足系统应用性能需求,对某些关系模式进行合并,减少关系的连接操作对系统查询性能的影响

  • 比如若应用对数据库的操作主要是进行查询操作,且查询涉及多个关系的属性时,DBMS可能要频繁进行关系的连接操作,为减小连接操作所花费的代价,可考虑将几个关系合并为一个关系

(三)在关系模式大的优化过程中,要注意以下几点

  • 并不是规范化程度越高的关系模式就越优
  • 低于BCNF的关系模式,虽然从理论分析上会存在不同程度的更新异常,但如果在实际应用中,只对此关系进行查询并不执行更新操作,则不会产生实际的影响
  • 对于一个具体的应用来说,到底关系模式优化到什么程度,需要权衡查询响应时间和更新操作问题两者的利弊

最后,给出教学信息管理案例系统的数据库逻辑设计的结果 

九、小结

  • 基于关系数据模型,将数据库概念结构设计的E-R模型转换为关系数据库模式,完成了数据库的逻辑结构设计 
  • 得到的数据库模式还需在给定的DBMS上用SQL语言定义为在DBMS中存储的逻辑结构,即进行数据库的物理结构设计

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/749135.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【深度学习】基于深度离散潜在变量模型的变分推理

1.引言 1.1.讨论的目标 阅读并理解本文后,大家应能够: 掌握如何为具有离散潜在变量的模型设定参数在可行的情况下,使用精确的对数似然函数来估计参数利用神经变分推断方法来估计参数 1.2.导入相关软件包 # 导入PyTorch库,用于…

LLM vs SLM 大模型和小模型的对比

语言模型是能够生成自然人类语言的人工智能计算模型。这绝非易事。 这些模型被训练为概率机器学习模型——预测适合在短语序列中生成的单词的概率分布,试图模仿人类智能。语言模型在科学领域的重点有两个方面: 领悟情报的本质。 并将其本质体现为与真实…

Java学习十一—Java8特性之Stream流

一、Java8新特性简介 2014年3月18日,JDK8发布,提供了Lambda表达式支持、内置Nashorn JavaScript引擎支持、新的时间日期API、彻底移除HotSpot永久代。 ​ Java 8引入了许多令人兴奋的新特性,其中最引人注目的是Lambda表达式和Stream API。以…

十年磨一剑,华火电燃组合灶重磅问世,引领厨房新时代

十年磨一剑,华火研发团队经过不懈努力,成功将等离子电生明火技术与电陶炉红外线光波炉技术精妙融合,打造出的这款具有划时代是意义的电燃组合灶HH-SZQP60,终于在 2024 年6月震撼登场,该灶以其卓越的创新技术和独特的产…

day01-项目介绍及初始化-登录页

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 day01-项目介绍及初始化-登录页一、人力资源项目介绍1.1项目架构和解决方案主要模块解决的问题 二、拉取项目基础代码1.引入库2.升级core-js版本到3.25.5按照完整依…

一篇文章带你玩懂数据库的基础函数

数据库的函数 单行函数1.数据函数2.字符串函数3.时间函数4.流程函数 多行函数聚合函数 阅读指南: 本文章讲述了对于数据库的单行和多行函数,如果读者感兴趣,后续我们会更新高级的操作在我们的对于数据库教程的合集中,大家可以来很…

振弦采集仪在大型工程安全监测中的应用探索

振弦采集仪在大型工程安全监测中的应用探索 振弦采集仪是一种用于监测结构振动和变形的设备,它通过采集振弦信号来分析结构的动态特性。在大型工程安全监测中,振弦采集仪具有重要的应用价值,可以帮助工程师和监测人员实时了解结构的状况&…

红队内网攻防渗透:内网渗透之内网对抗:横向移动篇Kerberos委派安全非约束系约束系RBCD资源系Spooler利用

红队内网攻防渗透 1. 内网横向移动1.1 委派安全知识点1.1.1 域委派分类1.1.2 非约束委派1.1.2.1 利用场景1.1.2.2 复现配置:1.1.2.3 利用思路1:诱使域管理员访问机器1.1.2.3.1 利用过程:主动通讯1.1.2.3.2 利用过程:钓鱼1.1.2.4 利用思路2:强制结合打印机漏洞1.1.2.5 利用…

利用Linked SQL Server提权

点击星标,即时接收最新推文 本文选自《内网安全攻防:红队之路》 扫描二维码五折购书 利用Linked SQL Server提权 Linked SQL server是一个SQL Server数据库中的对象,它可以连接到另一个SQL Server或非SQL Server数据源(如Oracle&a…

Techviz:XR协作工作流程,重塑远程电话会议新形式

在当今快速发展的数字环境中,无缝远程协作的需求正在成为企业多部门协同工作的重中之重,尤其是对于制造业、建筑和设计等行业的专业人士而言,这一需求更加迫切。传统的远程电话会议协作形式存在着延滞性,已经渐渐跟不上当今快节奏…

脑洞爆裂,OLED透明屏与红酒柜相结合

当OLED透明屏与红酒柜相结合时,我们可以设想一个极具创新性和实用性的产品,将科技美学与品酒文化完美融合。以下是我为这种结合提出的一些创新设想: 透明展示与虚拟标签 透明展示:OLED透明屏能够直接安装在红酒柜的玻璃门或侧面&a…

面试突击指南:Java基础面试题3

1.介绍下进程和线程的关系 进程:一个独立的正在执行的程序。 线程:一个进程的最基本的执行单位,执行路径。 多进程:在操作系统中,同时运行多个程序。 多进程的好处:可以充分利用CPU,提高CPU的使用率。 多线程:在同一个进程(应用程序)中同时执行多个线程。 多线程…

Redis 7.x 系列【9】数据类型之自动排重集合(Set)

有道无术,术尚可求,有术无道,止于术。 本系列Redis 版本 7.2.5 源码地址:https://gitee.com/pearl-organization/study-redis-demo 文章目录 1. 前言2. 常用命令2.1 SADD2.2 SCARD2.3 SISMEMBER2.4 SREM2.5 SSCAN2.6 SDIFF2.7 SU…

Jmeter,badboy学习

1、注意Jmeter与jdk之间的版本对应 2、Jmeter的作用: jmeter可以做接口测试和压力测试。其中接口测试的简单操作包括做http脚本(发get/post请求、加cookie、加header、加权限认证、上传文件)、做webservice脚本、参数化、断言、关联&#x…

Polyplus转染试剂的优点,你知道吗?

Polyplus专注于为生命科学研究、体内转染、生物制品制造以及细胞和基因治疗的客户,提供创新的核酸递送解决方案。其深耕转染领域,产品力强劲。在科研领域,其产品转染效果以及价格都优于lipo系列。无论是在基础科学研究中,还是在临…

Node.js下载及安装详细教程

目录 Node.js安装详细教程 下载安装环境变量配置文件结构配置npm在安装全局模块时的路径和缓存cache的路径测试常见命令 Node.js安装详细教程 👁官网下载地址:Download | Node.js (nodejs.org) 下载速度慢的话 可以使用网盘下载: https://pan.quark.…

文心一言 VS 讯飞星火 VS chatgpt (290)-- 算法导论21.3 3题

三、给出一个包含 m 个 MAKE-SET 、UNION 和 FINDSET 操作的序列(其中有 n 个是 MAKE-SET 操作),当仅使用按秩合并时,需要 Ω(mlgn) 的时间。如果要写代码,请用go语言。 文心一言: 在并查集(Union-Find)数…

RabbitMQ WEB管理端介绍

页面功能概览 Overview(概述)Connections(连接)Channels(通道)Exchanges(交换器)Queues(队列)Admin(用户管理)。 1. Overview(概述) 主要分为三部分 1.1 Queued messages(所有队列的消息情况) Ready:待消费的消息总数Unacked:待应…

今日好料(网易数据治理白皮书)

今日好料(网易数据治理白皮书) 在当前的数字经济时代,数据已经成为企业最重要的资产之一。然而,如何管理和利用这些数据,成为企业成功的关键所在。本文将探讨数据治理的概念、重要性及其实施策略,结合网易…

国标GB/T 28181详解:国标GBT28181-2022的目录通知流程

目录 一、定义 二、作用 1、实时同步设备目录状态 2、优化资源管理和调度 3、增强系统的可扩展性和灵活性 4、提高系统的可靠性和稳定性 5、支持多级级联和分布式部署 6、便于用户管理和监控 三、基本要求 1、目录通知满足以下基本要求 2、关键要素 (1…