第五讲 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模型扩展知识的更多相关文章

  1. 【数据库上】 第四讲 E-R模型基础知识

    第四讲 E-R模型基础知识 一.数据库设计过程 数据库设计的关键阶段? 各个阶段设计的主要任务? 基础条件:清楚一个应用系统的功能需求与数据需求(直接与用户交互.数据流程图示例/UML类图等) 核心阶 ...

  2. Yale数据库上的人脸识别

    一.问题分析 1. 问题描述 在Yale数据集上完成以下工作:在给定的人脸库中,通过算法完成人脸识别,算法需要做到能判断出测试的人脸是否属于给定的数据集.如果属于,需要判断出测试的人脸属于数据集中的哪 ...

  3. IIS 之 Web 服务器上的 ASP.NET 进程模型设置

    配置 Microsoft Internet 信息服务 (IIS) Web 服务器上的 ASP.NET 进程模型设置. processModel 节只能在 Machine.config 文件中进行设置, ...

  4. 数据库系统概论学习2-《关系数据库与 E/R 模型》

    -----------------------------一直更新学习内容------------------------------------ 建立一个关系数据库需要几步? 2.关系数据库与 E/ ...

  5. 扩展 ASP.NET MVC 模型扩展 – ASP.NET MVC 4 系列

           大部分人不能将核心运行时(System.Web 中的类)和 ASP.NET Web Forms 应用程序平台(System.Web.UI 中的类)区分开来.        ASP.NET ...

  6. Spark MLlib编程API入门系列之特征选择之R模型公式(RFormula)

    不多说,直接上干货! 特征选择里,常见的有:VectorSlicer(向量选择) RFormula(R模型公式) ChiSqSelector(卡方特征选择). RFormula用于将数据中的字段通过R ...

  7. MS SQL巡检系列——检查数据库上一次DBCC CHECKDB的时间

    DBCC CHECKDB检查指定数据库中的所有对象的逻辑和物理完整性,具体请参考MSDN文档.我们必须定期对数据库做完整性检查(DBCC CHECKDB),以便能及时发现一些数据库损坏(Corrupt ...

  8. 怎样将MySQL数据库上传到服务器

    首先,需要将本地的数据库导出来,作为一个数据文件,以备稍后上传到服务器用,在本地登陆phpmyadmin控制面板: 登陆成功后,在左侧选择需要操作的数据库: 选择后,页面会自动刷新,然后再在右边点击[ ...

  9. 使用Navicat for MySQL把本地数据库上传到服务器

    服务器系统基本都是基于linux的,这个数据库上传的方式适用于linux的各种版本,比如Ubuntu和Centos(尽管这两个版本各种大坑小坑,但至少在数据库传输上保持了一致性) 当然本地数据库上传到 ...

随机推荐

  1. ip地址分配

    目录 一.子网划分基础 二.子网划分的原理 三.IP地址汇总 四.ip地址规划 一.子网划分基础 二进制: 特点:基数为2,数值部分用2个不同的数字符号0.1表示逢二进一 IP地址:IP地址由32位二 ...

  2. nfs配置项在/etc/exports中的说明

    rw 可读写的权限 ro 只读的权限no_root_squash 登入NFS主机,使用该共享目录时相当于该目录的拥有者,如果是root的话,那么对于这个共享的目录来说,他就具有root的权       ...

  3. a href="tel" 拨打电话

    电话号码是固定的: <a href="'tel:10086">10086</a> 电话号码是动态获取时: 走默认的方式失败 <a href=" ...

  4. Java 日志框架概述(slf4j / log4j / JUL / Common-logging(JCL) / logback)

    一.简介 JAVA日志在初期可能官方并没有提供很好且实用的规范,导致各公司或OSS作者选择自行造轮子,这也导致了目前初学者觉得市面上 Java 日志库繁杂的局面. 现在市面流行以 slf4j(Simp ...

  5. Java线程基础及多线程的实现

    一.进程和线程 1.进程:正在运行的程序         是系统进行资源分配和调用的独立单位         每一个进程都有它自己的内存空间和系统资源 2.线程是进程中的单个顺序控制流,是一条执行路径 ...

  6. Go语言笔记[实现一个Web框架实战]——EzWeb框架(一)

    Go语言笔记[实现一个Web框架实战]--EzWeb框架(一) 一.Golang中的net/http标准库如何处理一个请求 func main() { http.HandleFunc("/& ...

  7. 用于在公网环境下测试的Telnet/SSH服务器

    google: public telnet server list for example: telnet nethack.alt.org ssh nethack@alt.org

  8. 手把手和你一起实现一个Web框架实战——EzWeb框架(五)[Go语言笔记]Go项目实战

    手把手和你一起实现一个Web框架实战--EzWeb框架(五)[Go语言笔记]Go项目实战 代码仓库: github gitee 中文注释,非常详尽,可以配合食用 本篇代码,请选择demo5 中间件实现 ...

  9. NOIP 模拟 7 考试总结

    T1 超级大水题,用 \(kmp\) 和 \(hash\) 均能过,但都忘了,结果只打了个暴力.难受.板子题,题解就不放了 Code #include<bits/stdc++.h> #de ...

  10. 剑指 Offer 68 - II. 二叉树的最近公共祖先

    剑指 Offer 68 - II. 二叉树的最近公共祖先 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先. 百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p.q,最近 ...