【数据库系统概念】第7-14章集合

文章目录

  • 第七章 数据库设计和E-R模型(重点!!!)
    • ~~7.1 设计过程概览(了解)~~
      • 7.1.1 设计阶段
      • 7.1.2 设计选择
    • ==7.2 实体-联系模型(重点掌握)==
      • 7.2.1 实体集
      • 7.2.2 联系集
        • 联系集的度
      • 7.2.3 属性
        • 各种属性在E-R图中的表示
    • 7.3 约束
      • 7.3.1 映射基数
      • 7.3.2 参与约束
      • 7.3.3 码
        • 键、码的概念
    • 7.4 从实体集中删除冗余属性
    • ==7.5 实体-联系图(重点!!!)==
      • 7.5.1 基本结构
      • 7.5.2 映射基数
      • 7.5.3 复杂的属性
      • 7.5.4 角色
      • 7.5.5 非二元的联系集
      • 7.5.6 弱实体集
      • 7.5.7 大学的E-R图
    • ==7.6 转换为关系模式(重点!!!)==
      • 7.6.1 具有简单属性的强实体集表示
      • 7.6.2 具有复杂属性的强实体集表示
      • 7.6.3 弱实体集的表示
      • 7.6.4 联系集的表示
    • 7.7 实体-联系设计问题
      • ==设计数据库的步骤==
    • ~~7.8 拓展的E-R属性~~
  • 第八章 关系数据库设计(重点!!!)
    • 8.1 好的关系设计的特点
      • 8.1.1 设计选择:更大的模式
      • 8.1.2 设计选择:更小的模式
    • 8.2 原子域和第一范式
    • 8.3 使用函数依赖进行分解
      • 8.3.1 码和函数依赖
        • **非规范化设计的问题:数据冗余,插入/删除/更新异常**
        • **函数依赖的概念(Functional Dependency)**
      • 8.3.2 Boyce-Codd 范式(Boyce-Codd Normal Form, BCNF)
      • 8.3.3 BCNF和保持依赖
      • 8.3.4 第三范式
      • ~~8.3.5 更高的范式(不考)~~
    • 8.4 函数依赖理论
      • 8.4.1 函数依赖集的闭包
      • 8.4.2 属性集的闭包
      • 8.4.3 正则覆盖
      • 8.4.4 无损分解
      • 8.4.5 保持依赖
    • 8.5 分解算法
      • 8.5.1 BCNF分解
      • 8.5.2 3NF分解
      • 8.5.3 3NF算法的正确性
      • 8.5.4 BCNF和3NF的比较
    • ~~8.6 使用多值依赖的分解(不考)~~
    • ~~8.7 更多的范式(不考)~~
    • ~~8.8 数据库设计过程(不考)~~
    • ~~8.9 时态数据建模(不考)~~
  • ~~9.10.11章不考~~
  • 第12章 查询处理考到12.5
  • 第14章 事务考到14.8
      • 事务
    • 应试

  • 重装系统……备份数据时把这个文件夹抛弃了……且不可能重新整理
  • 本文来源于能寻觅到的最后残骸
  • 目录如下,待有缘人使用
  • 文章不宜阅读and本系列文章止于此

第七章 数据库设计和E-R模型(重点!!!)

7.1 设计过程概览(了解)

7.1.1 设计阶段

7.1.2 设计选择

在软件开发中,需要经历这几个阶段

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

其中设计过程中需要进行数据库设计

关于E-R模式的引入

设计E-R模型的观点是,世界是由一组称为实体的基本对象和这些对象之间的联系构成的

E-R图的作用

帮助澄清用户数据需求,使分析人员和用户对数据需求达成高度一致
是数据逻辑模型设计的基础

7.2 实体-联系模型(重点掌握)

  数据库可被建模为:实体集合和实体间联系。

7.2.1 实体集

  • 实体是客观存在的对象并且与其他对象可区分,例如: 特定的人,公司,事件,植物,具有属性,例如:人具有姓名和地址,并且实体集是相同类型的实体的集合,他们具有相同的性质,例如:所有人的集合,所有公司的集合。
  • 实体集的图例如下,以instructor(导师)为例:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

实体用一个属性集合来表示,即实体集中所有成员都具有的描述性特性,域表示所有属性允许的值的集合。属性的种类有以下几种:

  • 简单属性与复合属性

  • 单值属性与多值属性

    • 例,多值属性:phone-numbers
  • 派生属性

    • 可由其他属性计算得到
    • 例,给定出生日期可计算出年龄
    • 基属性或存储属性
  • 复合属性的图例如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.2.2 联系集

联系是指多个实体之间的联系,联系集是相同类型联系的集合

  • 例如导师和学生的关系,一个学生有一个导师,一个导师可以有多个学生,导师的id用s_ID表示,student的id用i_ID表示,导师和学生的联系可以用如下数据表表示:
advisor(s_ID,i_ID)

一般联系集存放的是两个表的主键,对应的图示如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • 联系集也可具有属性,例如导师和学生双选的日期,如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

联系集的度

​ 联系集的度指的是参加联系的实体集的个数,涉及两个实体集的联系集称为二元的,联系集可以涉及多于两个的实体集,例:一个student在每个项目上最多只能有一位导师,如下图,包含三个实体集instructor、student和project(三元联系)(多于两个实体集之间的联系较少见,数据库系统中的联系集一般多为二元的)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.2.3 属性

  • 简单属性:不可再分的属性
  • 复合属性:可以划分为更小的属性,如Birthday = year + month + day
  • 单值属性:每个实体在该属性上的取值唯一
  • 多值属性:每个实体在该属性上的取值可以有多个,比如一个教师可能有多个电话号码
  • 派生属性:可以从其它相关属性或实体派生出来的属性,如教师(编号,姓名,出生日期,年龄),其中年龄即为派生属性,年龄可由当前年份-出生日期得到
各种属性在E-R图中的表示

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.3 约束

7.3.1 映射基数

二元联系集的映射基数有以下几种情况:

  • 一对一,如:就任总统(总统,国家)
    • 注意一对一不是一 一对应
  • 一对多,如:分班情况(班级,学生)
  • 多对一,如:就医(病人,医生)
  • 多对多,如:选课(学生,课程)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.3.2 参与约束

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.3.3 码

键、码的概念

​ 实体集的超码是能够唯一标识每个实体的一个或多个属性,候选码是实体集的最小超码,候选码可能存在多个,我们只会选择一个候选码作为主码或主键

  • 例:instructor (ID,name,dept_name,salary

  • 候选码:ID

  • 超码:{ID},{ID, name},{ID,…}

7.4 从实体集中删除冗余属性

自主忽略~

7.5 实体-联系图(重点!!!)

​ E-R图(E-R diagram)可以图形化表示数据库的全局逻辑结构。E-R图既简单又清晰,这些是致使E-R模型广泛使用的重要性质。

7.5.1 基本结构

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

实体集之间不可以相连,必须通过联系集。

7.5.2 映射基数

​ 在前面的7.3.1我们已经讨论过映射技术的四种形式,可以说任意二元联系都属于下面四种类型,现在我们用E-R图的形式表现出来。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.5.3 复杂的属性

​ 即上述简单-复合属性,单值-多值属性,派生属性等,见图7-11.

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.5.4 角色

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.5.5 非二元的联系集

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.5.6 弱实体集

​ 如果一个实体的所有属性合在一起都不足以形成主码,则称这样的实体为弱实体,反之称为强实体。同一类型的弱实体形成弱实体集

依赖于其他实体集的实体集都叫做弱实体集,例如课程实体集(course)和开课学期实体集(section),所开课程需要依赖于课程实体集,因为没有课程,也就没有开课信息,如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

在E-R图中,弱实体集和强实体集有相似之处,但有两点主要的区别

  • 弱实体集的分辨符以虚下划线标明,而不是实线
  • 关联弱实体集与强实体集的联系集用双菱形表示

7.5.7 大学的E-R图

​ E-R图如下图所示,矩形代表实体集,有阴影的第一部分包含实体集的名字, 第二部分包含实体集中所有属性的名字,菱形代表联系集,未分割的矩形代表联系集的属性。构成主码的属性以下划线标明,线段将实体集连接到联系集:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

参加联系的实体集不必是互不相同的

例,下图给出了course实体集和preq联系集之间的角色标识course_id和 prereq_id:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

上图中course_id表示课程id,prereq_id表示学习某一个课程的前置课程。

在开发中一般我们使用二元联系,任何非二元联系都能转换成二元联系,例,将如下非二元联系schooling 转换成二元联系

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

特化用从特化实体指向另一方实体的空心箭头来表示。这种关系为ISA关 系,代表“is a”(“是一个”)。例如,一个教师“是一个”雇员:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.6 转换为关系模式(重点!!!)

实体集和联系集都可以转化为关系模式,用以存储数据库中的内容。

若数据库符合E-R图,则可以表示成模式的集合。

在E-R图中,每个实体集和联系集均对应一个唯一的模式。

在每个模式中,均有多个列,且模式内列名不重复。

步骤:

1.转换强实体集; 2.转换弱实体集; 3.转换联系集(注意分情况讨论);

7.6.1 具有简单属性的强实体集表示

对于只有简单属性的强实体集,直接将E-R图转换为关系模式即可

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.6.2 具有复杂属性的强实体集表示

对于复合属性:将每个组合属性作为复合属性所在实体的属性
对于多值属性:将其转换为新的关系+所在实体的主码

复合属性全部拆开,多值属性建了一张新的表

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.6.3 弱实体集的表示

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.6.4 联系集的表示

7.7 实体-联系设计问题

设计数据库的步骤

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.8 拓展的E-R属性

第八章 关系数据库设计(重点!!!)

8.1 好的关系设计的特点

8.1.1 设计选择:更大的模式

8.1.2 设计选择:更小的模式

8.2 原子域和第一范式

如果一个域被认为是不可再分的单元,那么这个域是原子的

如果一个关系模式R的所有属性都是原子的,那么这个关系模式R属于第一范式(1NF)

注意要对这个原子性有正确的理解,具体的例子课本里有

8.3 使用函数依赖进行分解

​ 首先明确,我们学习和使用函数依赖的目的是什么?

​ 利用函数依赖,可以对现有关系进行分解,所以,函数依赖的本质作用是对现有的冗余的关系模式进行分解

关于后续相关符号的介绍

8.3.1 码和函数依赖

在现实世界中,数据通常存在各种约束,而满足所有这种约束的实例,被称为合法实例

现实世界中的约束可以转换为数据库中的码(超码,候选码,主码)

非规范化设计的问题:数据冗余,插入/删除/更新异常
  • 数据冗余(想修改一个属性,就要更新多行数据)
  • 插入异常(想要插入数据,结构因为表设计的问题,导致不能成功插入)
  • 删除异常(只想删除其中的某些数据 ,结果把不该删的也删了)
  • 更新异常(想更新一条数据,结果工作量大,还容易出错)
函数依赖的概念(Functional Dependency)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

8.3.2 Boyce-Codd 范式(Boyce-Codd Normal Form, BCNF)

8.3.3 BCNF和保持依赖

8.3.4 第三范式

8.3.5 更高的范式(不考)

8.4 函数依赖理论

8.4.1 函数依赖集的闭包

8.4.2 属性集的闭包

8.4.3 正则覆盖

8.4.4 无损分解

8.4.5 保持依赖

8.5 分解算法

8.5.1 BCNF分解

8.5.2 3NF分解

8.5.3 3NF算法的正确性

8.5.4 BCNF和3NF的比较

8.6 使用多值依赖的分解(不考)

8.7 更多的范式(不考)

8.8 数据库设计过程(不考)

8.9 时态数据建模(不考)

9.10.11章不考

第12章 查询处理考到12.5

第14章 事务考到14.8

事务

​ 事务(transaction)由查询和更新语句的序列组成。SQL标准规定当一条SQL语句被执行,就隐式地开始了一个事务。下列SQL语句之一会结束一个事务:

Commit work:提交当前事务,也就是将该事务所做的更新在数据库中持久保存。在事务被提交后,一个新的事务自动开始。

Rollback work:回滚当前事务,即撤销该事务中所有SQL语句对数据库的更新。这样,数据库就恢复到执行该事务第一条语句之前的状态

数据库系统概念笔记——第十四章:事务_设有两个事务t1和t2: t1从帐户a过户500元到帐户b t2从帐户a过户20%的余额到帐户b-CSDN博客

应试

方法:

  • E是边集,边集由满足先I=read(Q)后J=write(Q)先I=write(Q)后J=read(Q)先I=write(Q)后J=write(Q) 这三个条件之一的所有Ti→Tj的边组成
  • 若图无环,S是冲突可串行化的
  • 等价的串行调度是,按有向边出口依次截取结点

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++性能优化- perf 和火焰图的安装使用

工欲善其事必先利其器,要想做Linux下的程序性能优化,就得先知道当前性能的瓶颈在哪里。 这里主要介绍一下常用的工具:perf工具和火焰图的使用方法 本文中的命令都是自己在Ubuntu18.04系统上测试可用的,在其他系统可能会需要不同的…

[4K80 AI ISP IPC芯片]

4K80 AI ISP IPC芯片 Hi3403V100是一颗面向监控市场推出的专业 Ultra-HD Smart IP Camera SOC,该芯片最高支持四路sensor输入,支持最高4K60的ISP图像处理能力,支持3F WDR加粗样式、多级降噪、六轴防抖、硬件拼接等多种图像增强和处理算法&am…

内核线程创建-kthread_create

文章参考Linux内核线程kernel thread详解 - 知乎 大概意思就是早期创建内核线程,是交由内核处理,由内核自己完成(感觉好像也不太对呢),创建一个内核线程比较麻烦,会导致内核阻塞。因此就诞生了工作队列以及…

从vue小白到高手,从一个内容管理网站开始实战开发第六天,登录功能后台功能设计--API项目中的登录实现(二),工厂模式创建数据库连接

一、回顾 在第五天的时候我们开始创建后台所以需项目,并创建项目所需要的相关实体类,具体内容没有掌握的小伙伴可以看点击下面的链接去学习。 从vue小白到高手,从一个内容管理网站开始实战开发第六天,登录功能后台功能设计--API项目中的登录实现(一)-CSDN博客文章浏览阅读…

Java:多线程和JUC详解

文章目录 1、实现多线程1.1 多线程概念1.2 并发和并行1.3 进程和线程1.4 多线程实现方式1.4.1 继承Thread类1.4.2 实现Runnable接口1.4.3 实现Callable接口1.4.4 三种实现方式的对比 1.5 设置和获取线程名称1.6 线程休眠1.7 线程优先级1.8 守护线程1.9 礼让线程1.10 插队线程 2…

Golang高质量编程与性能调优实战

1.1 简介 高质量:编写的代码能否达到正确可靠、简洁清晰的目标 各种边界条件是否考虑完备异常情况处理,稳定性保证易读易维护 编程原则 简单性 消除多余的重复性,以简单清晰的逻辑编写代码不理解的代码无法修复改进 可读性 代码是写给人看…

Docker 镜像以及镜像分层

Docker 镜像以及镜像分层 1 什么是镜像2 Docker镜像加载原理2.1 UnionFs:联合文件系统2.2 Docker镜像加载原理2.3 Docker镜像的特点 3 镜像的分层结构4 可写的容器层 1 什么是镜像 镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行…

虾皮怎么上架商品:如何在Shopee上上架商品?完整步骤指南

在虾皮(Shopee)平台上上架商品是一个相对简单的过程,但是对于新手卖家来说可能会感到有些困惑。不用担心,本文将为您提供一个完整的指南,详细介绍在Shopee上上架商品的步骤和注意事项。 先给大家推荐一款shopee知虾数据…

【Redis】Redis基础

文章目录 1. 概述2. Redis 安装及配置3. key 常用命令及10 大数据类型4. Redis 持久化4.1 RDB (Redis Database)4.2 AOF(Append Only File)4.3 RDB-AOF混合持久化4.4 纯缓存模式 5. Redis 事务6. Redis管道7. Redis 主从复制&…

数据结构之堆——学习笔记

1.堆的简介: 接下来看一下堆的建立; 接下来是如何在堆中插入数据以及删除数据: 大根堆的插入操作类似只是改变了一下大于和小于符号,同时插入操作的时间复杂度为O(logn)。 来看几个问题: 答案当…

从零开始C++精讲:第一篇——C++入门

文章目录 前言一、C关键字二、命名空间2.1引子2.2命名空间定义2.3命名空间的使用 三、C输入和输出3.1输出3.2输入 四、缺省参数4.1全缺省4.2半缺省 五、函数重载5.1重载概念 六、引用6.1定义6.2引用的使用示例6.2.1引用作参数6.2.1引用作返回值 6.3传值、传引用效率比较6.4常引…

【亚马逊云科技】使用Helm 3为Amazon EKS部署Prometheus+Grafana监控平台

文章目录 1. 创建Kubernetes命名空间2. 添加Prometheus社区helm chart3. 安装prometheus4. 检查Prometheus Pod运行状况5. 检查Prometheus Service部署情况6. 修改服务访问端口类型7. 访问Prometheus数据收集情况8. 访问Grafana9. 设置数据源10. 查看Kubernetes各类性能可视化参…