数据库系统原理——备考计划2:数据库系统的概述

news2025/1/17 6:00:40

前言:

基于课本、上课ppt、复习总结ppt进行一个知识点的罗列,方便后期高效地复习


目录

前言:

一、基本概念

1.数据:

(1)概念:

(2)数据的种类:

(3)数据的定义:

2.数据库:

(1)概念:

(2)特点:

3.大数据:

二、数据库技术的产生、发展

1.人工管理阶段:

2.文件系统阶段:

3.数据库系统阶段:

4.三个阶段的比较:

三、数据库系统的体系结构

1.数据库系统( DataBase System,DBS)定义:

2.数据库系统的组成:

3.内部体系结构——三级模式和二级映像结构

(1)三级模式——外模式(子模式/用户模式)——>视图

(2)三级模式——模式(逻辑模式/概念模式)——>基本表

(3)三级模式——内模式(存储模式/物理模式)——>存储文件

(4)二级映像——外模式/模式映像:保证数据和程序之间的逻辑独立性

(5)二级映像——模式/内模式映像:保证数据的物理独立性

4.外部体系结构:

四、数据库管理系统(DataBase Management System)

1.主要功能

2.组成

(1)系统运行控制程序

(2)语言编译处理程序

(3)系统建立、维护程序

(4)数据字典

3.数据存取过程

五、数据模型

1.概念

2.分类:

(1)概念模型:

(2)逻辑模型(数据模型)和物理模型:

3.构成:

(1)数据结构

(2)数据操作

(3)数据的完整性约束

4.层次数据模型

(1)概念

(2)数据增删改

(3)优点

(4)缺点

5.网状数据模型

(1)概念

(2)数据增删改

(3)优点

(4)缺点

6.关系数据模型——二维表

(1)概念

(2)优点

(3)缺点

7.面向对象数据模型——对象和对象标识

(1)概念

(2)优点

(3)缺点

六、数据库系统的发展

七、数据库技术展望


一、基本概念

1.数据:

(1)概念:

        数据是数据库中存储的基本对象

(2)数据的种类:

  • 数字是数据最简单的一种形式
  • 文本、图像、音频、视频等都是数据

(3)数据的定义:

  • 是用来记录信息的可识别的符号组合
  • 是信息的具体表现形式

2.数据库:

(1)概念:

  • 长期存储在计算机中的有组织的、可共享的大量数据和数据对象的集合
  • 在计算机中按照一定的格式存储数据的仓库

(2)特点:

  • 按一定的数据模型组织、描述和存储;
  • 具有较小的的数据冗余、较高的数据独立性;
  • 可为多种用户共享;
  • 能以安全和可靠的方法进行数据的检索和存储。

3.大数据:

无法在一定时间范围内使用常规软件工具进行捕捉、管理和处理的数据集合是需要新处理模式才能具有更强的决策力、 洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产

二、数据库技术的产生、发展

1.人工管理阶段:

数据不保存,不共享,无独立性, 无专用软件管理数据

图2-1 应用程序与数据间的对应关系

2.文件系统阶段:

以文件形式长期保存,由文件系统管理 数据 ,程序与数据间有一定独立性

图2-2 应用程序与数据间的对应关系

3.数据库系统阶段:

数据结构化 ,共享性高、冗余度低 , 独立性高 ,有统一的数据控制功能(DBMS)

图2-3 应用程序与数据间的对应关系

4.三个阶段的比较:

人工管理

文件系统

数据库系统

应用领域

科学计算

科学计算管理

大规模管理 

硬件需求

无直接存取存

储设备

磁盘、磁鼓

大容量磁盘

软件需求

没有操作系统

文件系统

数据库管理系统

数据共享

无共享,冗余

度极大

共享性差,冗余

度大

共享性高,冗余度小

数据独立性

不独立,完全

依赖于程序

独立性差

高度的物理独立性和逻

辑独立性

数据结构化

无结构

记录内有结构,

整体无结构

整体结构化,用数据模

型描述

三、数据库系统的体系结构

1.数据库系统( DataBase System,DBS)定义:

是实现有组织地、动态地存储大量关联数据、方便多用户访问的计算机硬件、软件和数据资源组成的系统,即是采用数据库技术的计算机系统。

2.数据库系统的组成:

数据库、数据库管理系统、数据库应用系统、数据库管理员和用户等组成

图3-1 数据库系统的组成

(1)用户:

  • 终端用户:非计算机专业人员使用数据库
  • 应用程序员:设计和编制应用程序
  • 数据库管理员:负责设计、建立、管理和维护数据库以及协调用户对数据库要求的个人或工作团队

(2)硬件系统:

        存储和运行数据库系统的硬件设备。

3.内部体系结构——三级模式和二级映像结构

数据库系统的三级模式之间的联系通过二级映像实现,实际的映像转换工作由数据库管理系统完成。因为一个数据库系统中只有唯一一个数据库,因此其的内模式和模式是唯一的,但建立在数据库系统上的应用不唯一,也就是说外模式可以有多个

图3-2  数据库系统的三级模式和二级映像

(1)三级模式——外模式(子模式/用户模式)——>视图

概念模式的某一部分的抽象表示

  • 是数据库用户能看到并允许使用的那部分局部数据的逻辑结构和特征的描述
  • 是数据库用户的数据视图
  • 是与某一应用有关的数据的逻辑表示

   不同的用户由不同的需求和访问权限,因此一个数据库可以有多个外模式

(2)三级模式——模式(逻辑模式/概念模式)——>基本表

整个数据库实际存储的抽象表示

  • 是数据库中全体数据的逻辑结构和特征的描述,又称数据模式
  • 是所有用户的公共数据视图

   数据的逻辑结构包括数据记录的名称、组成的数据项的名称、类型、取值范围等

(3)三级模式——内模式(存储模式/物理模式)——>存储文件

整个数据库实际存储的表示

  • 是对数据库存储结构的描述
  • 是数据在数据库内部的表示方式 
  • 是数据库最低一级的逻辑描述

   一般由数据库管理系统(DBMS)提供的定义语言来定义内模式,对于一般的用户来说是 透明看不见的。

图3-3 SQL语言支持的关系数据库的三级模式结构

(4)二级映像——外模式/模式映像:保证数据和程序之间的逻辑独立性

当数据库的逻辑结构(模式)发生变化时,应用程序的外部视图不受影响。这意味着应用程序可以保持不变,即使数据库的逻辑结构发生变化。这种独立性使得数据库的设计和实现可以相对独立于应用程序的设计和实现,从而提高了系统的灵活性和可维护性。

(5)二级映像——模式/内模式映像:保证数据的物理独立性

数据库系统中的内部模式(也称为物理模式)可以独立于外部模式(用户视图)和概念模式(逻辑模式)进行改变,而不会影响到应用程序和用户的数据访问方式。

换句话说,当数据库的物理存储结构发生变化时,外部模式和概念模式不受影响,用户和应用程序无需进行修改,仍然可以通过相同的方式访问数据。

4.外部体系结构:

(1)单用户结构——数据库放在一台计算机上,不能共享数据

(2)主从式结构——大型主机带多个终端;主机处理,终端输出

(3)分布式结构——是分布在计算机网络上的多个逻辑相关的数据库的集合

(4)客户机/服务器结构(C/S结构)——把DBMS的功能与应用程序分开

(5)浏览器/服务器结构(B/S结构)——将客户端运行的应用程序转移到应用服务器上

四、数据库管理系统(DataBase Management System)

1.概念:

数据库管理系统是一种系统软件,它负责管理数据库的创建、维护、访问和控制。

同时也是位于用户与操作系统间的一层数据管理软件,它提供了对数据库的管理和操作接口,为用户和应用程序提供了对数据库的访问能力。

通常在对庞大的数据库进行日常维护,并能够快速在大量的数据中找到所需要的数据的时候就需要使用到数据库管理系统。

‘图4-1 DBMS在计算机系统中的位置

2.主要功能

(1)数据定义功能

(2)数据操纵功能

(3)数据库运行管理功能

(4)数据库的建立和维护功能

(5)数据通信接口

(6)数据组织、存储和管理

2.组成

(1)系统运行控制程序

  • 系统总控程序
  • 安全性控制程序
  • 完整性控制程序
  • 并发控制程序
  • 数据存取和更新程序
  • 通信控制程序

(2)语言编译处理程序

  • 数据定义语言DDL编译程序
  • 数据操纵语言DML编译程序

(3)系统建立、维护程序

  • 装配程序
  • 重组程序
  • 系统恢复程序

(4)数据字典

        描述数据库中有关信息的数据目录

3.数据存取过程

(1)对得到的结果进行必要的处理,如格式转换等

(2)DBMS对存取数据库执行必要的存取操作

(3)DBMS接受请求并将该请求解释转换成机器代码指令

(4)用户向DBMS发出存取请求

(5)DBMS依次检查外模式、外模式/模式映象、模式、模式/内模式映象及存储结构定义

(6)从对数据库的存取操作中接受结果

(7)将处理的结果返回给用户

五、数据模型

1.概念

(1)数据:是描述事物的符号记录。

(2)模型:是现实世界的抽象。

(3)数据模型:

  • 是数据特征的抽象
  • 是数据库系统中用以提供信息表示和操作手段的形式架构
  • 是数据库系统中用以提供信息表示和操作手段的形式构架

2.分类:

(1)概念模型:

根据用户的观点对数据和信息建模,是对现实世界存在的事物和联系的第一级抽象

(2)逻辑模型(数据模型)和物理模型:

逻辑模型是按计算机的观点对数据建模;物理模型是对数据最底层的抽象

3.构成:

(1)数据结构

  • 层次结构
  • 网状结构
  • 关系结构

(2)数据操作

  • 数据查询操作
  • 数据更新操作(插入、修改、删除)

(3)数据的完整性约束

        保证数据的正确性、有效性和相容性

4.层次数据模型

(1)概念

图4-1 层次数据模型

  • 层次模型表现为一棵倒立的树;

  • 根以外的其他结点有且仅 有一个双亲结点;

  • 父子结点之间的联系是一 对多(1:n)的联系 。

(2)数据增删改

数据插入进行插入操作时,如果没有相应的双亲结点值就不能插入子女结点值。
数据删除进行删除操作时,如果删除双亲结点值,则相应的子女结点值也被同时删除。
数据修改修改操作时,应修改所有相应的记录,以保证数据的一致性。

(3)优点

  • 结构简单,层次分明
  • 查询效率高
  • 提供良好的数据完整性支持
  • 数据就具有共享性、安全性、完整性

(4)缺点

  • 很难实现多对多联系
  • 该模型数据库缺乏灵活性,插入和删除数据限制太多
  • 无法直接查询子女结点,得须通过双亲结点

5.网状数据模型

(1)概念

特点:

有一个以上的结点没有双亲结点。

允许结点有多个双亲结点。

允许两个结点之间有多种联系(复合联系)

图4-2 网状数据模型

  • 是采用有向图结构表示记录型与记录型之间联系的数据模型
  • 每个结点表示一个记录型,每个记录型可包含若干个字段,记录型描述的是实体。
  • 结点间的带箭头的连线(或有向边)表示父子的联系。

(2)数据增删改

数据插入插入数据时,允许插入尚未确定双亲结点值的子女结点值。
数据删除删除数据时,允许只删除双亲结点值。
数据修改修改数据时,只需更新指定记录即可。

(3)优点

  • 可表示实体间的多种复杂(多对多)联系;
  • 具有良好的性能和存储效率。

(4)缺点

  • 数据结构复杂;
  • 数据定义语言、数据操纵语言复杂;
  • 用户需要了解系统结构的细节。

6.关系数据模型——二维表

(1)概念

简单来说就相当于一张二维表。

图4-3  关系数据模型

(2)优点

  • 简单,有严格的数学理论根据;
  • 结构简单清晰,用户易懂易用;
  • 灵活强大的查询能力;
  • 更高的数据独立性、易于设计实现维护和使用。

(3)缺点

  • 查询效率;
  • 硬件开销;
  • 容易设计不好。

7.面向对象数据模型——对象和对象标识

(1)概念

将系统工程中的某个模块和构件是为问题空间的一个或一类对象,

  • 对象是现实世界中实体的模型化;
  • 对象标识独立于对象的内容和存储位置,是一种逻辑标识符,由系统产生,在整个系统范围内是唯一;
  • 两个对象即使内部状态值和方法都相同,如标识符不同,仍认为是两个相等而不同的对象;
  • 每个对象都包含一组属性和一组方法。

(2)优点

  • 适合处理各种数据类型;
  • 面向对象程序设计与数据库技术结合;
  • 提高开发效率;
  • 改善数据访问。

(3)缺点

  • 没有准确的定义;
  • 维护困难;
  • 不适合所有的应用。

六、数据库系统的发展

传统数据库

第一代:

格式化数据模型

(层次数据模型和 网状数据模型)  

支持三级模式的体系结构; 用存取路径来表示数据之间的联系; 独立的数据定义语言; 导航的数据操纵语言。

第二代:

关系数据模型

概念单一; 以关系代数为基础; 数据独立性强; 关系数据库语言是非过程化的。

缺点:

面向机器的语法数据模型;

数据类型简单、固定 ;

结构与行为完全分离 ;

被动响应 。

第三代
面向对象的数据模型支持面向对象的数据模型; 保持或继承第二代数据库系统的优点; 具有开放性。

七、数据库技术展望

数据库技术与分布处理技术相结合,出现了分布式数据库。

数据库技术与人工智能技术相结合,出现了演绎数据库、主动数据库和知识库等。

数据库技术与多媒体技术相结合,出现了多媒体数据库。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【UE】夜视仪效果

效果 步骤 1. 新创建一个空白项目,勾选“光线追踪”选项 新建一个Open World关卡 添加一个“第一人称游戏”到项目 将角色蓝图放入场景中 设置自动控制玩家 2. 打开第一人称角色蓝图“BP_FirstPersonCharacter”,添加一个后期处理组件,该组件…

运维知识点-SQLServer/mssql

SQLServer/mssql Microsoft structed query language常见注入提权 技术点:0x00 打点前提 0x01 上线CS0x02 提权0x03 转场msf0x04 抓取Hash0x05 清理痕迹 Microsoft structed query language 常见注入 基于联合查询注入 order by 判断列数(对应数据类型…

C++二分查找算法:包含每个查询的最小区间

本文涉及的基础知识点 二分查找算法合集 作者推荐 动态规划LeetCode2552:优化了6版的1324模式 题目 给你一个二维整数数组 intervals ,其中 intervals[i] [lefti, righti] 表示第 i 个区间开始于 lefti 、结束于 righti(包含两侧取值&a…

【Lustre相关】应用部署-03-Lustre集群部署实践(软raid方案)

文章目录 一、前言1、硬件配置2、组网拓扑3、总体方案 二、软件安装三、集群部署1、配置多路径2、配置高可用集群3、配置zpool4、部署lustre5、配置Lustre角色高可用6、配置Lustre状态监控6.1、Lustre网络状态监控6.2、Lustre集群状态监控6.3、配置优化6.3.1、设置故障恢复不回…

7Docker搭建es和kibana

一、安装es 1.拉取镜像 sudo docker pull elasticsearch:7.12.0 elasticsearch:7.12.0:我安装的版本是7.12.0,可以根据实际的情况安装 创建docker容器挂在的目录: sudo mkdir -p /opt/elasticsearch/config sudo mkdir -p /opt/elasticsearch/data s…

TA-Lib学习研究笔记——Overlap Studies(二)上

TA-Lib学习研究笔记——Overlap Studies(二) 1. Overlap Studies 指标 [BBANDS, DEMA, EMA, HT_TRENDLINE, KAMA, MA, MAMA, MAVP, MIDPOINT, MIDPRICE, SAR, SAREXT, SMA, T3, TEMA, TRIMA, WMA]2.数据准备 get_data函数参数(代码&#x…

沿着马可·波罗的足迹,看数字云南

刚入行的时候,有位前辈跟我说过一句话:去现场“要像外国人一样去看”,重新审视那些自己可能早已“熟视无睹”的事物。 前不久,我跟随“看见数字云南——云南数字经济媒体探营活动”,奔赴昆明、大理、西双版纳等地&…

springmvc(基础学习整合)

SpringMVC是Spring框架提供的构建Web应用程序的全功能MVC模块。 在SpringMVC的各个组件中,处理器映射器、处理器适配器、视图解析器称为SpringMVC的三大组件。 springMVC基本介绍: http://t.csdnimg.cn/TOzw9 MVC是一种设计思想,将一个应…

基于ssm的汽车论坛管理系统设计与实现

基于ssm的汽车论坛管理系统设计与实现 摘要:信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题…

WordPress 粘贴图片上传插件

找了很久,发现一款不错的插件,允许我们直接粘贴图片文件并且上传到媒体库。以前的插件上传后媒体库不会显示,这个要显示。 启用后编辑器会有一个图标,如果开启,那么久可以截图后直接粘贴了。 学习资料源代码&#xf…

每日一题:LeetCode-283. 移动零

每日一题系列(day 08) 前言: 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 &#x1f50e…

Django大回顾 -3 之响应对象、cbv和fbv、关于类中self是谁的问题、上传文件、模版

【1】isinstance方法 判断一个对象是否是一个已知的类型。 isinstance语法: isinstance(object,classinfo) object --------- 实例化对象 cassinfo ------- 可以是字节或间接类名、基本类型,或者由他们组成的元组 相同返回True,不…

数据挖掘 感知机

要使用感知机,我们首先要引入头文件,以下是感知机用的到头文件: import pandas as pd import numpy as np import matplotlib.pyplot as plt from sklearn.linear_model import Perceptron from sklearn.model_selection import train_test_…

【刷题】树的遍历

层序遍历 层序遍历需要用到广度有限搜索,也就是需要队列 1.将根节点加入队列、 2.如果队列不为空,就得到队列的长度,对队列中现有的元素进行访问并从队列中删除,并将其子节点加入到队列中 102. 二叉树的层序遍历 给你二叉树的根…

css浮动属性学习

在此文, html菜单的基本制作-CSDN博客 已经看到css 浮动属性的效果;下面单独看一下浮动属性; 做4个div,设置不同的背景色,不为div添加float属性;效果如下; 因为div是块级元素,默认…

开源播放器GSYVideoPlayer + ViewPager2 源码解析

开源播放器GSYVideoPlayer ViewPager2 源码解析 前言一、GSYVideoPlayer🔥🔥🔥是什么?二、源码解析1.ViewPager2Activity 总结 前言 本文介绍GSYVideoPlayer源码中关于ViewPager2 GSYVideoPlayer 实现的滑动播放列表的实现原理。…

(C++)复写零--双指针法

个人主页:Lei宝啊 愿所有美好如期而遇 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://le…

enote笔记法之附录1——“语法词”(即“关联词”)(ver0.24)

enote笔记法之附录1——“语法词”(即“关联词”)(ver0.24) 最上面的是截屏的完整版,分割线下面的是纯文字版本: 作者姓名(本人的真实姓名):胡佳吉 居住地&#xff1…

A*算法学习

系列文章目录 前言 在总结 2023华为软件精英挑战赛——全赛段思路分享与总结 - 知乎 (zhihu.com)时,发现自己还有很多技术细节没搞懂,这里看静态全局路径规划最常见的A*算法,这个博主讲得很好: A-Star(A*&#xff0…

AI模特换装的前端实现

本文作者为 360 奇舞团前端开发工程师 随着AI的火热发展,涌现了一些AI模特换装的前端工具(比如weshop网站),他们是怎么实现的呢?使用了什么技术呢?下文我们就来探索一下其实现原理。 总体的实现流程如下&am…