• 数据库操作


    1687583151602-698001b0-b394-4817-87db-bb691ff8144d.png

    1. 数据库模式

    三级模式两级映射

    1687587930183-f0ce91f2-ffc1-4370-aaba-d4c276abd699.png

    1.1. 关系表类型

    关系的三种类型

    • 基本关系(通常又称为基本表或基表):实际存在的表,实际存储数据的逻辑表示。
    • 查询表:查询结果对应的表。
    • 视图表:由基表和其它视图表导出的表,本身不独立存储,数据库只存放它的定义,常称为虚表。

    数据库视图它一个虚拟表(逻辑上的表),其内容由查询定义(仅保存SQL查询语句)。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并没有真正存储这些数据,而是通过查询原始表动态生成所需要的数据。

    视图的优点

    1. 视图能简化用户操作
    2. 视图使用户能以多种角度看待同一数据
    3. 视图对重构数据库提供了一定程度的逻辑独立性
    4. 视图可以对机密数据提供安全保护

    物化视图它不是传统意义上虚拟视图,是实体化视图,其本身会存储数据。同时当原始表中的数据更新时,物化视图也会更新。【多查少更新】

    1.2. 分布式数据库

    • 数据独立性。除了数据的逻辑独立性与物理独立性外,还有数据分布独立性(分布透明性)。
    • 集中与自治共享结合的控制结构。各局部的DBMS可以独立地管理局部数据库,具有自治的功能。同时,系统又设有集中控制机制,协调各局部DBMS的工作,执行全局应用。
    • 适当增加数据冗余度。在不同的场地存储同一数据的多个副本,可以提高系统的可靠性和可用性,同时也能提高系统性能。(提高系统的可用性,即当系统中某个节点发生故障时因为数据有其他副本在非故障场地上,对其他所有场地来说,数据仍然是可用的,从而保证数据的完备性。)
    • 全局的一致性、可串行性和可恢复性

    1687589344245-1730583c-5317-429d-9830-097f76673c20.png

    分布式数据库管理系统-组成

    • LDBMS
    • GDBMS
    • 全局数据字典
    • 通信管理(CM)

    1687589421775-065eec73-f1e5-45c7-91f5-b3c5ae0a4d52.png

    分布式数据库管理系统-结构

    • 全局控制集中的DDBMS
    • 全局控制分散的DDBMS
    • 全局控制部分分散的DDBMS

    分布透明性

    • 分布透明性
      • 水平分片
      • 垂直分片
      • 混合分片
    • 位置透明性
    • 局部数据模型透明性

    分片透明是指用户不必关心数据是如何分片的,它们对数据的操作在全局关系上进行,即如何分片对用户是透明的。

    复制透明用户不必关心数据库在网络中哥哥节点的复制情况,被复制的数据的更新都由系统自动完成。

    位置透明是指用户不必知道所操作的数据放在何处,即数据分配到哪个或哪些站点存储对用户是透明的。

    局部映像透明性(逻辑透明)是最低层次的透明性,该透明性提供数据到局部数据库的映像,即用户不必关心局部DBMS支持哪种数据模型、使用哪种数据操作语言,数据模型和操纵语言的转换是由系统完成的。因此,局部映像透明性对异构型和同构异质对分布式数据库系统是非常重要的。

    1.2.1. 两阶段提交协议2PC

    2PC事务提交的两个阶段

    • 表决阶段,目的是形成一个共同的决定
    • 执行阶段,目的是实现这个协调者的决定

    两条全局提交规则

    • 只要有一个参与者撤销事务,协调者就必须做出全局撤销决定
    • 只有所有参与者都同意提交事务,协调者才能做出全局提交决定

    1687692184592-6364b229-9f6c-4406-9009-2ab36896fc4d.png

    1687692225745-320d9f90-caed-46e3-9968-de8b9877ca71.png

    1687692243818-f32a9b81-658b-4615-904f-e673fc69dfcf.png

    2. 数据库设计过程

    1687692515394-e1e67317-4145-4171-ac19-0361b68c82ce.png

    1687692591662-183c3dfa-1dcf-47f2-949b-6643c1dbebb1.png

    2.1. 概念结构设计

    E-R图(实体联系图)

    1687692703531-caa69794-f988-4750-9d4b-3d4cdbd62a61.png

    两个不同实体集之间联系

    • 一对一(1:1)
    • 一对多(1:n)
    • 多对多(m:n) *:*

    1687692877935-540e2301-e4ec-499e-8e76-02b9103f7e64.png

    1687693735174-f34dc193-9a9f-452f-afb3-d7597f3281a4.png

    集成的方法:

    • 多个局部E-R图一次集成。
    • 逐步集成,用累加的方式一次集成两个局部E-R。

    集成产生的冲突及解决办法:

    • 属性冲突:包括属性域冲突和属性取值冲突。
    • 命名冲突:包括同名异义和异名同义。
    • 结构冲突:包括同一对象在不同应用中具有不同的抽象,以及同一实体在不同局部E-R图中所包含的属性个数和属性排列次序不完全相同。

    1687694262196-e8aaa391-26e3-48fe-854f-ae0d32a5bb59.png

    3. 逻辑结构设计

    数据模型三要素:数据结构、数据操作、数据的约束条件。

    层次模型

    网状模型

    面向对象模型

    关系模型

    1687694437384-49f2a433-589c-436c-bec9-b476d189728f.png

    学生(学号,姓名,年龄,班级编号)

    • 目或度关系模式中属性的个数,,如上则为4目或4度
    • 候选码(候选键)

    1687694592048-7e205a6d-b3ba-4ecf-bdc4-4f7a05fab137.png

    • 主码(主键)

    1687694650944-d3a54376-f091-4a9f-881a-2420c5de2192.png

    • 主属性与非主属性组成候选码的属性就是主属性,其他的就是非主属性。
    • 外码(外键)
    • 全码(ALL-Key)关系模式的所有属性组是这个关系的候选码

    1687694821490-e9b0c351-b367-4d36-a20d-658939e4b5ff.png

    3.1. 完整性约束

    • 实体完整性约束规定基本关系的主属性不能取空值。
    • 参照完整性约束:关系与关系间的引用,其他关系的主键或空值。
    • 用户自定义完整性约束:应用环境决定。
    • 触发器

    1687695518261-0695f605-566e-4c4a-8e6e-021513813eec.png

    1687695573805-0f7b30b1-babc-402d-8c7f-d0ddb5c62374.png

    1687695687918-903a9257-9ee0-442e-bd00-b4dee585f8ce.png

    3.2. 逻辑结构设计

    1687696072068-4f87e642-9589-4d64-adb7-45e3b9a6f7d0.png

    • E-R图向关系模式的转换
      • 实体向关系模式的转换
      • 联系向关系模式的转换
    • 关系模式的规范化
    • 确定完整性约束(保证数据的正确性)
    • 用视图的确定(提高数据的安全性和独立性)
      • 根据数据流图确定处理过程使用的视图
      • 根据用户类别确定不同用户使用的视图
    • 应用程序设计

    一个实体必须转换为一个关系模式

    联系转关系模式:

    1687696336432-95c3167c-c5e9-4f54-a39d-2bdfec1f6395.png

    1. 一对一联系的转换有两种方式。
      1. 独立的关系模式:并入两端主键及联系自身属性。(主键:任意一端)
      2. 归并(任意一端):并入另一端主键及联系自身属性。(主键:保持不变)
    1. 一对多联系多转换有两种方式。
      1. 独立的关系模式:并入两端主键及联系自身属性。(主键:多端主键)
      2. 归并(多端):并入另一端主键及联系自身属性。(主键:保持不变)
    1. 多对多联系多转换只有一种方式
      1. 独立的关系模式:并入两端主键及联系自身属性。(主键:两端主键的组合键)

    1687696849858-d5eeb93d-774d-41db-8291-134cd03e63f5.png

    1687696916513-34fa3b64-96bc-4b6a-a135-6fd255f06b57.png

    1687697051001-72e89d5b-8f29-4564-beda-0b67bc4eabf1.png

    4. 关系代数

    4.1. 并、交、差

    1687697734423-cf80bd55-b7e1-424c-93ed-58ef49d1b7cf.png

    4.2. 笛卡尔积、投影、选择

    S1 X S2

    S1的每条记录与S2的每条记录拼接,属性列数是两者之和,属性行数是两者成绩 3 * 3 = 9

    1 = 4,即S1第一列等于S2第一列

    1687698061636-fe4ffd73-9433-4a4d-b0a3-f55da6d0f6b6.png

    Select___投影____ from___笛卡尔积____where___选择___

    4.3. 自然连接

    列:二者之和去重复,,5 - 1 = 4

    行:所有属性都相等的

    通过笛卡尔积的投影和选择操作可以得到自然连接,先投影还是先选择?

    先选择

    性能:

    1. 一般认为自然连接优于笛卡尔积。
    2. 尽可能压缩运算表(先做选择)

    1687698562614-a4ddc2a2-3978-44f5-8b3c-3d94c052151a.png

    4.4. 练习题

    1687698727736-cdd84a8d-0fa1-4537-a206-7177fd00a2a4.png

    1687698816940-be478cb7-2d02-4070-9059-2b213a05ac60.png

    E2和E4,E2效率更高但是E4少做了一个等值。

    1687699205636-deccb672-35e5-4d42-9bdd-814348892239.png

    5. 规范化理论

    5.1. 非规范化的问题

    没有达到第三范式,这些问题都会存在

    1687699433328-b4d8db22-2428-4e57-9360-13e0b9bff52f.png

    5.2. 规范化理论基本概念

    5.2.1. 函数依赖

    设R(U,F)是属性U上的一个关系模式,X和Y是U的子集,r为R的任一关系,如果对于r中的任意两个元组u, v, 只要有u[X]=v[Y], 则称X函数决定Y,或称Y函数依赖于X,记为X->Y。

    1687700851547-38d2237e-040c-4a2f-891a-6f5238cf44ea.png

    左侧叫做决定因素,右侧叫做被决定因素。

    5.2.2. 键

    1687700929285-f88887f5-b486-49bf-b9a0-ca5de1fc93ee.png

    主属性与非主属性组成候选码的属性就是主属性,其他的就是非主属性。

    求候选键:

    • 将关系模式的函数依赖关系用“有向图”的方式表示
    • 找入度为0的属性,并以该属性集合为起点,尝试遍历有向图,若能正常遍历图中所有节点,则该属性集即为关系模式的候选键
    • 若入度为0的属性集不能遍历图中所有节点,则需要尝试性的将一些中间节点(既有入度,也有出度的节点)并入入度为0的属性集中,直至该集合能便利所有节点,集合为候选键。

    1687702151085-098e15b5-e3ba-4147-90e3-65a0d152afc1.png

    1687702274130-5e2ea185-b977-4f23-bba5-c52cd7f49244.png

    5.3. Armstrong公理系统

    1687702640180-f8f1f204-148c-42d5-9285-6dc167651e1f.png

    自反律:由一个较大板块可以确定一个较小板块,如:身份证号和姓名能唯一确定身份证号,也能唯一确定姓名,AB->A AB->B

    1687702821550-77c9e825-aea4-4ed9-a5a1-1c7ea5268192.png

    1687702877062-1914598c-bcac-4d13-a772-877e36430838.png

    5.4. 范式判断

    1688180778590-a46678cd-f2f2-46da-8ec2-0a26ae6aa754.png

    5.4.1. 第一范式

    第一范式(1NF):在关系模式R中,当且仅当所有域只包含原子值,即每个属性都是不可再分的数据项,则称关系模式R是第一范式。

    属性可再分

    简单属性和复合属性、单值属性多值属性、NULL属性、派生属性

    例如:关系模式R(系名称,高级职称人数)是否满足1NF,如果不满足,应如何调整?

    1688181947594-d60caf5d-ea54-4e36-a366-6b03047931d5.png

    5.4.2. 第二范式

    第二范式(2NF):当且仅当实体E是第一范式(1NF),且每一个非主属性完全依赖主键(不存在部分依赖)时,则称实体E是第二范式。

    候选键只有一个依赖

    1688182989001-222db1df-b3a0-47f8-8ea3-9b6496bd1ff7.png

    • 满足第一范式
    • 拆分(课程号、学分)
    • 学号和课程号组合键、学分

    拆分:(课程号,学分)、(学号、课程号、成绩)

    5.4.3. 第三范式

    第三范式(3NF):当且仅当实体E是第二范式(2NF),且E中没有非主属性传递依赖于码时,则称实体E是第三范式。

    1688183853941-84f12190-4a14-4975-897a-6a336f562427.png

    • 系单独组表,系号、系名、系位置
    • 学号、姓名、系号(保证两个表关联性)

    5.4.4. BC范式

    BC范式(BCNF):设R是一个关系模式,F是它的依赖集,R属于BCNF当且仅当其F中每个依赖的决定因素必定包含R的某个候选码。

    1688184547843-3da8494e-2708-451a-bad8-8ff9f7731b06.png

    候选码:SJ、ST

    T -> J ,T不包含候选码,所以不满足BC范式

    5.4.5. 练习题

    1688184741012-675dc6ad-dc7e-452f-a8bc-9cc8771865d6.png

    5.5. 模式分解

    5.5.1. 是否保持函数依赖

    保持函数依赖分解

    设数据库模式P={R1, R2, ..., Rk}是关系模式R的一个分解,F是R上的函数依赖集,P中每个模式Ri上的FD集是Fi。如果{F1, F2, ..., Fk}与F是等价的(即相互逻辑蕴涵),那么称分解P保持FD。

    1690708740900-965cc71c-32ee-4d89-9b6e-792f58d0f216.png

    无损分解

    1690708942140-46fc1444-3b36-4945-be76-802940f46743.png

    1691207649442-5e9764ce-f174-4506-aa46-2bdc9c5ec2bd.png

    什么是有损,什么又是无损?

    • 有损:不能还原。
    • 无损:可以还原。

    无损连接分解:指将一个关系模式分解成若干个关系模式后,通过自然连接和投影等运算仍能还原到原来的关系模式。

    1691208563880-c594b616-eaa7-4b06-a9ba-926a033b5b10.png

    表格法:

    1691208725283-130cbc6e-f736-4efd-9214-2b04a055cec3.png

    公式法:

    1691208929731-313822f6-2401-4235-aab9-3164039f6876.png

    1691209223018-893ee6de-a80f-4cab-a568-3caf145eac6f.png

    1691209606087-bc84009b-73b1-49f1-bd2e-fa3ccd776510.png

    1NF:所有属性不可再分

    2NF:存在非主属性对候选键的部分函数依赖,比如候选键是组合键,存在有的属性只依赖了它其中一个。

    6. 数据库控制技术

    6.1. 并发控制

    6.1.1. 事务的ACID特性

    1691210239081-582f21a9-231a-4d6d-86b5-c4c5ed9aa584.png

    6.1.2. 封锁协议

    1691211698800-5256da9a-f335-4256-927d-1c317ce9b59b.png

    • 一级封锁协议:事务T再修改数据R之前必须先对其加X锁,知道事务结束才释放。可防止丢失修改
    • 二级封锁协议:一级封锁协议加上事物T在读取数据R之前先对其加S锁,读完后即可释放S锁。可防止丢失修改,还可防止读“脏”数据
    • 三级封锁协议:一级封锁协议加上事务T在读取数据R之前先对其加S锁,知道事务结束才释放。可防止丢失修改、防止读“脏”数据与防止数据(不可)重复读。
    • 两段锁协议。可串行化的。可能发生死锁

    丢失更新加锁:

    一级封锁协议:

    解决丢失更新的问题

    1691216805068-a21791aa-33bd-4b69-aea1-0b1cffdf33aa.png

    读“脏”数据加锁

    1691216922520-a8d8c4fe-a48b-4f92-90ff-81b521ab504c.png

    不可重复读加锁:

    1691217047778-e5906cbb-0892-4917-a5eb-042dae56f47e.png

    6.2. 数据库的安全性

    1691217456742-420d122b-65b7-4aae-a8f5-78522d6fbaf1.png

    1691217553434-dfab7cf5-711a-4ab1-8bf1-25d038eb21d1.png

    6.3. 数据库备份与恢复技术

    6.3.1. 数据备份

    • 冷备份也称为静态备份,是将数据库正常关闭,在停止状态下,将数据库的文件全部备份(复制)下来。
    • 热备份也称为动态备份,是利用备份软件,在数据库正常运行的状态下,将数据库中的数据文件备份出来。

    1691217846090-206ddf25-fd22-4f8e-a6ac-0c0e11f6dbd2.png

    • 完全备份:备份所有数据
    • 差量备份:仅备份上一次完全备份之后变化的数据
    • 增量备份:备份上一次备份之后变化的数据

    日志文件:事务日志是针对数据库改变所做的记录,它可以记录针对数据库的任何操作,并将记录结果保存在独立的文件中。

    遵循原则:先写日志,再写数据库

    1691218138942-33453f39-fcd8-480f-9e9b-7f6f6345ef10.png

    假如在周六发生故障,则恢复:

    • 先找全备(周日A)
    • 再找差备(周五 BCDEF)
    • 最后增备(周六G)

    6.3.2. 数据库故障与恢复

    1691218382883-015d8b88-e06f-4251-afd8-f91a6e5e26b4.png

    • 撤销事务(UNDO):故障发生时未完成的事务,放入Undo撤销。
    • 崇左事务(REDO):故障发生前已提交的事务,放入Redo重做。

    1691218555725-659a2205-ad4b-407f-8efc-0fd559d0c3df.png

    7. 章节回顾

    1691218659462-1b5346a0-afd2-4627-bf19-dcd28c8b6df9.png

     

     

     

     

     

     

     

     

     

  • 相关阅读:
    iOS应用加固方案解析:ipa加固安全技术全面评测
    1.Django安装和项目创建
    开天aPaaS平台实现最新汽车新闻资讯查询
    Midjourney中文版来了,这里有一份保姆级上手指南!
    arc 166 b
    《C++新经典》第16章 智能指针
    高清沉浸式体验:基于 RTC 的全景 8K@120fps FoV 实践
    人工智能在教育上的应用2-基于大模型的未来数学教育的情况与实际应用
    记录一个hive中跑insert语句说没创建spark客户端的问题
    多输入多输出 | MATLAB实现CNN-GRU-Attention卷积神经网络-门控循环单元结合SE注意力机制的多输入多输出预测
  • 原文地址:https://blog.csdn.net/qq_33599109/article/details/133736570