关系模型的基本术语

定义:用二维表格来表示实体集,用关键码表示实体之间联系的数据模型称为关系模型

有时也习惯称呼关系为表或表格,元组为行(Row),属性为列。关系中属性个数称为“元数”,元组个数称为“基数”

关键码(Key,简称键):由一个或多个属性组成

超键(Super Kry):在关系中能唯一标识元组的属性集称为关系模型的超键

候选键:不含有多余属性的超键称为候选键

主键:(Primary Key):用户选作元组标识的候选键称为主键,一般不加说明,键是指主键

外键:(Foreign Key):如果模式R中属性K是其他模式的主键,那么K在在模式R中称为外键

关系的定义和性质

定义:关系是一个属性数目相同元组的集合

关系是一种规范化了的二维表格,对于关系作了下列规范性限制:

  1、关系中每一个属性都是不可分解的

  2、关系中不允许出现重复的元组(即不允许出现相同的元组)

  3、由于关系是一个集合,因此不考虑元组间的顺序,即没有顺序

  4、元组中属性在理论上也是无序的,但使用时按习惯考虑列的顺序

三类完整性规则

实体完整性规则:关系中元组在组成主键的属性上不能有空值,如果有空值,那么就起不到唯一标识元组的作用

参照完整性规则:K是关系模式R1中的主键,是关系模式R2中的外键,那么K在R2中的取值有俩种,或者为空值,或者等于R1关系中某个主键值(不允许应用不存在的实体)

用户定义的完整性规则

ER模型到关系模型的转换

ER图中的主要成分是实体类型和联系类型,转换算法就是如何把实体类型、联系类型转换成关系模式

实体类型的转换:将每个实体类型转换成一个关系模式,实体的属性即为关系模式的属性,实体标识符即为关系模式的键

联系类型的转换(一、二元联系类型的转换)

  1、若实体间联系是1:1,可以在俩个实体类型转换成的俩个关系模式中任意一个关系模式的属性中加入另一个关系模型的键(作为外键)和联系类型的属性

  2、若实体间联系是1:N,则在N端实体类型转换成的关系模式中加入1端实体类型的键(作为外键)和联系类型的属性

  3、若实体间的联系为M:N,则将联系类型也转换成关系模式,其属性为俩端实体类型的键(作为外键)加上联系类型的属性,而键为两端实体键的组合

实体转换为关系模型

系(系编号,系名,电话)

教师(教工号,姓名,性别,职称)

课程(课程号,课程,学分)

联系转换为关系模型

1:1联系“主管”,可以在系模式中加入“教工号”(教工号为外键)------系(系编号,系名,电话,教工号

1:N联系“聘用”,可以在“教师”模式中加入系编号和聘期俩个属性(系编号为外键)---------教师(教工号,姓名,性别,职称,系编号,聘期)

1:N联系“开设”,可以在“课程”模式中加入系编号(系编号为外键) - ---------------------------课程(课程号,课程,学分,系编号

M:N联系“任教”,则生成一个新的关系模式-------------------------------------------------------------任教(教工号,课程号,学分)

这样结合起来的最终结果为:

系(系编号,系名,电话)

教师(教工号,姓名,性别,职称,系编号,聘期)

课程(课程号,课程,学分,系编号

任教(教工号,课程号,学分)

联系类型的转换(三元联系类型的转换)

  1、若实体间联系是1:1:1,可以在三个实体类型转换成的三个关系模式中任意一个关系模式的属性中加入另两个关系模型的键(作为外键)和联系类型的属性

  2、若实体间联系是1:1:N,则在N端实体类型转换成的关系模式中加入两个1端实体类型的键(作为外键)和联系类型的属性

  3、若实体间联系是1:M:N,则将联系类型也转换成关系模式,其属性为M端和N端实体类型的键(作为外键)加上联系类型的属性,而键为M端和N端实体键的组合

  4、若实体间联系是M:N:P,则将联系类型也转换为关系模式,其属性为三端实体类型的键(作为外键)加上联系类型的属性,而键为三端实体键的组合

仓库(仓库号,仓库名,地址)

商店(商店号,商店名)

商品(商品号,商品名)

进货(仓库号,商店号,商品号,日期,数量)

采用ER模式的逻辑设计步骤

关系数据库的逻辑设计步骤有以下五步:

1、导出初始关系模式集

2、规范化处理

3、模式评价(主要包括功能和性能俩个方面)

4、模式修正

5、设计子模式

数据库设计和ER模型-------之关系模型的基本概念(第二章)的更多相关文章

  1. 数据库设计与 ER 模型 - 数据库系统原理

    数据库系统生存周期 数据库应用系统的开发是一项软件工程,一般具有信息的采集.组织.加工.抽取.综合.传播等功能,但又有自己的特点,所以称为 数据库工程. 数据库应用系统从开始规划.设计.实现.维护到最 ...

  2. ER图/模型转换为关系模型

    ER图中的主要成分是实体类型和联系类型,转换规则就是如何把实体类型.联系类型转换成关系模式. 1. 二元联系转换 规则1.1(实体类型的转换):将每个实体类型转换成一个关系模式,实体的属性即为关系模式 ...

  3. 数据库系统概论——从E-R模型到关系模型

    E-R模型和关系模型都是现实世界抽象的逻辑表示 E-R模型并不被 DBMS直接支持,更适合对现实世界建模 关系模型是 DBMS直接支持的数据模型 基本 E-R图中的元素包括实体集.联系集.属性 椭圆框 ...

  4. ER模型到关系模型的转换规则

    E-R模型向关系模型的转换规则: 一.两元联系的转换规则 (1)实体类型的转换 将每个实体类型转换成一个关系模式,实体的属性即为关系的属性,实体标识符即为关系的键. (2)联系类型的转换 a实体间的联 ...

  5. 数据库系统(四)---关系型数据库设计及E-R图

    1.关系型数据库: 关系型数据库是一类采用关系模型作为逻辑数据模型的数据库系统,遵从数据库设计的基本步骤,包括:需求分析.概念结构设计.逻辑结构设计.物理结构设计.数据库实施.数据库的运行和维护等阶段 ...

  6. 数据库——数据库设计 E-R图向关系模型的转换

    1.将下列物资管理E-R图转换为关系模式: 转换原则 ⒈  一个实体型转换为一个关系模式.关系的属性:实体型的属性关系的码:实体型的码   ⒉ 一个m:n联系转换为一个关系模式(初步,以后可能调整). ...

  7. MySQL数据分析-(5)数据库设计之ER模型

    大家好,我是jacky,很高兴跟大家分享本课时的内容,从本节课开始,就开始了我们第二章的学习,第一章我们抛出了若干问题,从第二章开始往后,都是解决问题的一个过程: 第一章的案例中,我们拿手机销售公司举 ...

  8. 数据库设计和ER模型-------之ER模型的基本概念(第二章)

    ER模型(实体联系模型)的基本元素 实体:是一个数据对象,在ER模型中,实体用方框表示,方框内注明实体的名称 联系:表示一个或多个实体之间的关联关系,联系用菱形框表示,并用线段将其与相关的实体联系起来 ...

  9. 数据库设计和ER模型-------之数据库系统生存期(第二章)

    数据库设计 概念:开发人员利用开发环境表达用户要求.设计构造最优的数据模型,然后据此建立数据库以及其应用系统,这个过程称为数据库设计 数据库生存期 1968年首次提出“软件工程”的概念 概念:我们把数 ...

随机推荐

  1. 集群RedHat6.5+JDK1.8+Hadoop2.7.3+Spark2.1.1+zookeeper3.4.6+kafka2.11+flume1.6环境搭建步骤

    1.RHEL 6.5系统安装配置图解教程(rhel-server-6.5) 2.在Linux下安装JDK图文解析 3.RedHat6.5上安装Hadoop集群 4.RedHat6.5安装Spark集群 ...

  2. 微信支付app的各种坑

    android: 签名要一致,要导出singed包 要记得重启手机 如果别人的都可以支付,我的不可以,就要退出微信账号,重新登陆微信账号一下(不仅仅是退出微信应用). 上面还不行的话,就要重新换个微信 ...

  3. ML平台_设计要点

    如果说机器是人类手的延伸.交通工具是人类腿的延伸,那么人工智能就是人类大脑的延伸,甚至可以帮助人类自我进化,超越自我.人工智能也是计算机领域最前沿和最具神秘色彩的学科,科学家希望制造出代替人类思考的智 ...

  4. Vivado中ILA的使用

    Vivado中ILA的使用 1.编写RTL代码      其中需要说明的是(* keep = "TRUE" *)语句的意识是保持cnt信号不被综合掉,方便以后的调试,是否可以理解为 ...

  5. hyperledger fabric各类节点及其故障分析 摘自https://www.cnblogs.com/preminem/p/8729781.html

    hyperledger fabric各类节点及其故障分析   1.Client节点 client代表由最终用户操作的实体,它必须连接到某一个peer节点或者orderer节点上与区块链网络通信.客户端 ...

  6. mysql5.7 主从同步

    一:进行bin-log日志配置 1设置bin-log日志 [mysqld] log-bin=//路径  #<===红色的加粗的省去 server-id = 1    #主库 2.检查配置登录数据 ...

  7. .net webapi 收不到json 实体类参数,返回的json中带有k__BackingField

    案例:实体类是从WCF项目中复制到webapi项目中,去掉了[DataContract],[DataMember],但[Serializable] 没去掉. 在ApiController 中,实体类输 ...

  8. c#读取Sybase中文乱码的解决办法

    最近需要从Sybase数据库中获取数据.用Sybase.Data.AseClient连接的话比较简单,但中文数据会有乱码.用Sybase自带的工具SQL Advantage设置好编码和语言,是可以正常 ...

  9. Boost--lexical_cast 一个方便安全高效的string转换库

    #include "boost\lexical_cast.hpp" #include <vector> #include <iostream> #inclu ...

  10. Zuul Read Time out 错误

    只改application.yml文件即可: eureka: client: serviceUrl: defaultZone: http://localhost:7087/eureka/ server ...