【数据库上】第五讲 E-R模型扩展知识
第五讲 E-R模型扩展知识
一、E-R模型设计主意问题
1.1 用实体还是实体集
案例:学院对象的表示
应将各个学院看做实体集,还是实体?
方法一:将各个学院看作一个实体集
如果各学院具有不同属性特征,则设计合理
否则面临问题:每增加一个学院增加一个实体,需修改应用代码
方法二:将所有学院看作一个实体集
一般地,一所学校的所有的学院具有相同属性,应看作属于一个实体集的不同实体
1.2 确认属性的位置
案例:学生成绩的表示
学生的课程“成绩”应放在图中何处?
设计方法一:放在学生实体集中
无法区分是哪门课程
设计方法二:放在课程实体集中
难以区分是哪个学生的成绩
设计方法三:放在联系上
合理,因学生和课程之间是多对多的关系
1.3 用属性还是实体集
案例:工资和岗位的表示
职工的每月有工资,且可能不同
职工可能同时在不同部门担任不同的职务
案例:电话信息的表示
一人一个电话时:电话为人的属性
一人多个电话时,还有其他特俗属性时,电话应作为一个实体
多值属性和复合属性
零件的销售价格是一个多值属性(经销、代销、批发、零售)
(1)将原来的多值属性用几个单值属性来代替
(2)将原来的多值属性用一个新的实体集来代替
这个新实体和原来的实体之间是1:N联系;新实体依赖于原实体而存在,称为弱实体,在E-R模型中,弱实体用双线矩阵表示;与弱实体相关的联系,用双线菱形表示。
1.4 用实体集还是联系集
案例:选课信息的表示
描述学生所选课程,应该采用实体集还是联系集?
设计原则:通常地,采用联系来表示发生在两个实体集之间的一个动作,如选课!
如果仅描述学生选课,用选课联系
如果强调学生为上何课程,要求到教务处去办报名注册,则应用一个实体集及两个联系。
案例:家属(爱人)信息的表示
分情况
1.5 用二元联系还是多元联系
案例:父母关系的表示
案例:教师指导学生做项目的表示
二 扩展E-R模型
2.1 特化与概化(特殊化与一般化)
如何理解特化与概化?
一个实体集(父)可能含有一个子实体集!
子实体集具有(继承)父实体集的属性,还可能具有其它一些独特属性,特化与概化专门用于描述这种现象。
特化:自顶向下的设计过程
概化:自底向上的设计过程
由下向上的箭头连线为一种“is a”联系。
案例:学校人员信息
2.2 聚集
聚集:是一种抽象,它将联系集(及其相关实体集)看做是一个更高层的抽象实体集。
【数据库上】第五讲 E-R模型扩展知识的更多相关文章
- 【数据库上】 第四讲 E-R模型基础知识
第四讲 E-R模型基础知识 一.数据库设计过程 数据库设计的关键阶段? 各个阶段设计的主要任务? 基础条件:清楚一个应用系统的功能需求与数据需求(直接与用户交互.数据流程图示例/UML类图等) 核心阶 ...
- Yale数据库上的人脸识别
一.问题分析 1. 问题描述 在Yale数据集上完成以下工作:在给定的人脸库中,通过算法完成人脸识别,算法需要做到能判断出测试的人脸是否属于给定的数据集.如果属于,需要判断出测试的人脸属于数据集中的哪 ...
- IIS 之 Web 服务器上的 ASP.NET 进程模型设置
配置 Microsoft Internet 信息服务 (IIS) Web 服务器上的 ASP.NET 进程模型设置. processModel 节只能在 Machine.config 文件中进行设置, ...
- 数据库系统概论学习2-《关系数据库与 E/R 模型》
-----------------------------一直更新学习内容------------------------------------ 建立一个关系数据库需要几步? 2.关系数据库与 E/ ...
- 扩展 ASP.NET MVC 模型扩展 – ASP.NET MVC 4 系列
大部分人不能将核心运行时(System.Web 中的类)和 ASP.NET Web Forms 应用程序平台(System.Web.UI 中的类)区分开来. ASP.NET ...
- Spark MLlib编程API入门系列之特征选择之R模型公式(RFormula)
不多说,直接上干货! 特征选择里,常见的有:VectorSlicer(向量选择) RFormula(R模型公式) ChiSqSelector(卡方特征选择). RFormula用于将数据中的字段通过R ...
- MS SQL巡检系列——检查数据库上一次DBCC CHECKDB的时间
DBCC CHECKDB检查指定数据库中的所有对象的逻辑和物理完整性,具体请参考MSDN文档.我们必须定期对数据库做完整性检查(DBCC CHECKDB),以便能及时发现一些数据库损坏(Corrupt ...
- 怎样将MySQL数据库上传到服务器
首先,需要将本地的数据库导出来,作为一个数据文件,以备稍后上传到服务器用,在本地登陆phpmyadmin控制面板: 登陆成功后,在左侧选择需要操作的数据库: 选择后,页面会自动刷新,然后再在右边点击[ ...
- 使用Navicat for MySQL把本地数据库上传到服务器
服务器系统基本都是基于linux的,这个数据库上传的方式适用于linux的各种版本,比如Ubuntu和Centos(尽管这两个版本各种大坑小坑,但至少在数据库传输上保持了一致性) 当然本地数据库上传到 ...
随机推荐
- Javas数组03——数组的使用
Javas数组--数组的使用 1.普通的for循环 2.for-each循环 3.数组做方法入参 4.数组做返回值 例子1--普通for循环 package array; public clas ...
- Java 多线程与并发【知识点笔记】
Java 多线程与并发[知识点笔记] Java多线程与并发 先说一下线程与进程的由来: 在初期的计算机,计算机只能串行执行任务,并且需要长时间的等待用户的输入才行 到了后来,出现了批处理,可以预先将用 ...
- 加载GIF图片优化方案
前言 许多项目需要加载GIF图片,但是在直接使用UIImageView加载存在许多问题,于是查找资料做了一个加载GIF的Demo,思路来源. 思路 使用FLAnimatedImage来加载GIF图片, ...
- 使用JDBC(Dbutils工具包)来从数据库拿取map类型数据来动态生成insert语句
前言: 大家在使用JDBC来连接数据库时,我们通过Dbutils工具来拿取数据库中的数据,可以使用new BeanListHandler<>(所映射的实体类.class),这样得到的数据, ...
- Linux下库的制作(静态库与共享库)
库中实际上就是已编译好的函数代码,可以被程序直接调用. Linux下的库一般的位置在/lib或者/usr/lib中 静态库 静态库是复制拷贝到调用函数中的,函数运行的时候不再需要静态库,因为静态库是在 ...
- 陀螺仪、加速度计与MPU6050的关系
文章目录 一.引言 二.陀螺仪 三.加速度计 四.MPU6050 一.引言 要开始做俩轮平衡小车了,所以需要补充一些关于平衡小车的知识,首先就是如何让小车保持平衡,这是要依据小车当前的三轴角度和平衡位 ...
- .Net Core with 微服务 - 分布式事务 - TCC
上一次我们讲解了分布式事务的 2PC.3PC .那么这次我们来理一下 TCC 事务.本次还是讲解 TCC 的原理跟 .NET 其实没有关系. TCC Try 准备阶段,尝试执行业务 Confirm 完 ...
- HTTP状态码关于各个网站的实地调查
我使用的是新版Edge浏览器,右键,点击检查,点击网络,可以看到请求的各种文件.那么以此来看看状态码的使用吧. 101 与websocket相关,websocket在慕课网中的应用 - KeBoom ...
- NOIP 模拟 $21\; \rm Game$
题解 考试的时候遇到了这个题,没多想,直接打了优先队列,但没想到分差竟然不是绝对值,自闭了. 正解: 值域很小,所以我们开个桶,维护当前最大值. 如果新加入的值大于最大值,那么它肯定直接被下一个人选走 ...
- 从0开始搭建一个IoC容器(C#版)
网址:https://blog.csdn.net/wangyahua1234/article/details/100619695 目录 1. IoC简介 2. Tiny版IoC的功能 3. Tiny版 ...