数据库系统概论——绪论

news/2024/4/27 12:36:30/文章来源:https://blog.csdn.net/fgets__/article/details/129182063

1、绪论

1.1、数据库系统概述

数据库系统的构成示意图

在这里插入图片描述

1.1.1、数据库系统基本概念

基本概念:数据、数据库、数据库管理系统和数据库系统

1)数据(data)

  • 定义:描述事物的符号记录称为数据
  • 数据是数据库中存储的基本对象。

2) 数据库(DB)

  • 定义:数据库是长期储存在计算机内、有组织的、可共享的大量数据集合。
  • 特征:数据按一定的数据模型组织、描述和储存
    • 可为各种用户共享
    • 冗余度较小
    • 数据独立性
    • 易扩展

3)数据库管理系统(DBMS)

  • 定义:数据库管理系统(DBMS),是位于用户与操作系统之间的一层数据管理软件。数据库管理系统和操作系统一样是计算机的基础软件。
  • DBMS的主要功能:
    • 数据定义功能:提供定义语言(DDL)数据组织、存储和管理
    • 数据操纵功能:提供数据操作语言(DML)
    • 数据库的事务管理和运行管理
    • 数据库的建立和维护功能

4)数据库系统(DBS)

  • 数据库系统(DBS)是由数据库、数据库管理系统(及其开发工具)、应用程序和数据库管理员(DBA)组成的存储、管理、处理和维护数据的系统。

1.1.2、数据管理技术的产生与发展

数据管理技术经历了人工管理、文件系统管理、数据库系统3个阶段

1)人工管理阶段

  • 人工管理数据的特点
    • 数据不保存
    • 应用程序管理数据
    • 数据不共享
    • 数据不具有独立性
  • **缺点:**数据的逻辑结构或物理结构发生变化后,必须对应程序做出相应的修改,这就加重了程序员的负担。

2)文件系统阶段

  • 文件系统管理数据的特点:
    • 数据可以长期保存
    • 由文件系统管理数据
  • 缺点:
    • 数据共享性差、冗余度大
    • 数据独立性差

3)数据库阶段

  • 数据库管理数据的特点:
    • 数据结构化
    • 数据共享性高,冗余度低,易扩充
    • 数据独立性高
    • 数据由DBMS统一管理和控制

1.2、数据模型

数据模型(DM)也是一种模型,它是对现实世界数据特征的抽象。数据模型就是现实世界的模拟。

1.2.1、两类数据模型

  • 数据模型满足的要求
    • 能比较真实地模拟现实世界
    • 容易为人所理解
    • 便于在计算计算机上实现

1)第一类是概念模型

概念模型,也称为信息模型,它是按用户的观点来对数据和信息建模,主要用于数据库的设计

  • 概念模型要求
    • 具有较强的语义表达能力
    • 能够方便、直接地表达应用中的各种语义知识
    • 简单、清晰、易于用户理解
  • 信息世界中的概念
    • 实体(entity):客观存在并可相互区别的事务称为实体。
    • 属性(attribute):实体所具有的某一特征称为属性。
    • 码(key):唯一标识实体的属性集称为码。
    • 域(domain):一组具有相同数据类型的值的集合称为域。属性的取值范围来自某个域。
      • 例如:学号的域为8位整数,学生年龄的域为整数,性别的域为(男、女)
    • 实体型(entity type):用实体名及其属性名集合来抽象和刻画同类实体,称为实体型。
      • 例如,学生(学号,姓名,性别,出生年月,所在院系,入学时间)就是一个实体型。
    • 实体集(entity set):同一类型的集合称为实体集。
    • 联系:实体之间的联系通常是指不同实体集之间的联系。
      • 实体之间的联系有一对一、一对多和多对多等多种类型。
  • 概念模型的一种表示方法:实体—联系图(E—R图)
    • 实体型:用矩形表示
    • 属性:用椭圆表示
    • 联系:用菱形表示

2)第二类是逻辑模型物理模型

  • 逻辑模型主要包括层次模型网状模型关系模型、面向对象模型和对象模型等。对数据进行建模,用于DBMS的实现。
  • 物理模型是对数据最底层的抽象,它是描述数据在系统内部的表达方式和存取方法,或在磁盘或磁带上的存储方式和存取方法,是面向计算机系统的

1.2.2、 数据模型的组成要素

数据模型通常由数据结构数据操作数据的完整性约束条件三部分组成。

1)数据结构描述数据库的组成对象以及对象之间的联系

2)数据操作是指对数据库中各种对象(型)的实例(值)允许执行的操作的集合,包括操作及有关的操作规则。

3)数据的完整性约束条件是一组完整性规则

1.2.3、常用的数据模型

  • 层次模型
  • 网状模型
  • 关系模型
  • 面向对象数据模型
  • 对象关系数据模型
  • 半结构化数据模型

1)层次模型

  • 层次模型的数据结构
    • 在数据库定义中满足下面两个条件的基本层次联系的集合为层次模型
      • 有且只有一个节点没有双亲节点,这个结点称为根节点。
      • 根以外的其他节点有且只有一个双亲节点。
    • 层次模型像一棵倒立的数,节点的双亲是唯一的。
  • 层次模型的数据操纵与完整性约束
    • 层次模型的数据操纵主要有查询、插入、删除和更新。进行插入、删除、更新操作是要满足层次模型的完整性约束条件。
    • 完整性约束
      • 进行插入操作时,如果没有相应的双亲结点值就不能插入它的子女节点值。
      • 进行删除操作时,如果删除双亲结点值,则相应的子女节点值也将被同时删除。
  • 层次模型的优缺点
    • 优点
      • 层次模型的数据结构比较简单清晰。
      • 层次数据库的查询效率高。
      • 层次数据模型提供了良好的完整性支持。
    • 缺点
      • 现实世界中很多联系是非层次性的,如结点之间具有多对多联系,不适合用层次模型表示。
      • 如果一个结点具有多个双亲结点等,用层次模型表示这类联系就很笨拙,只能通过引入冗余数据或创建非自然的数据结构来解决。
      • 查询子女节点必须通过双亲节点。
      • 由于结构严密,层次命令趋于程序化。

2)网状模型

  • 网状模型的数据结构
    • 在数据库中,把满足以下两个条件的基本层次联系结合称为网状模型:
      • 允许一个以上的节点无双亲
      • 一个结点可以有多于一个的双亲
    • 层次模型中子女结点与双亲节点的联系是唯一的,而在网状模型中这种联系可以不唯一。
  • 网状模型的优缺点
    • 优点
      • 能够更为直接地描述现实世界,如一个结点可以有多个双亲,结点之间可以有多种联系。
      • 具有良好的性能,存取效率高。
    • 缺点
      • 结构比较复杂,而且随着应用环境的扩大,数据库的结构就变得越来越复杂,不利于最终用户掌握。
      • 网状模型的DDL、DML复杂,并且要嵌入某一种高语言中。
      • 由于记录之间的联系是通过存取路径实现的,应用程序在访问数据时必须选择适当的存取路径,因此用户必须了解系统结构的细节,加重了编写应用程序的负担。

3)关系模型

  • 关系模型的数据结构

    • 关系(relation):一个关系对应通常说的一张表。
    • 元组(tuple):表中的一行即为一个元组。
    • 属性(attribute):表中的一列即为一个属性,给每一个属性起一个名称即属性名。
    • 码(key):也可称为码键。表中的某个属性,它可以为以确定一个元组。
    • 域(domain):域是一组具有相同数据类型的值的集合。
    • 分量:元组中一个属性值。
    • 关系模式:对关系的描述,一般表示为
      • 关系名(属性1,属性2,…,属性m)
      • 例如:教师(教工编号,姓名,年龄,性别,系名)
  • 关系模型的数据操纵与完整性约束

    关系模型的数据操纵主要包括查询、插入、删除和更新数据。

    • 关系的完整性约束条件包括三大类
      • 实体完整性
      • 参照完整性
      • 用户定义的完整性
  • 关系模型的优点:

    • 关系模型与格式化模型不同,它是建立在严格的数学概念基础上的。
    • 关系模型的概念单一。
    • 关系模型的存取路径对用户透明,从而具有更高的数据独立性、更好的安全保密性,也简化了程序员的工作和数据库开发建立的工作。

1.3、数据库系统结构

1.3.1、数据库系统模式的概念

模式(Schema)是数据库中全体数据的逻辑结构和特征的描述,同一个模式可以有很多实例。

1.3.2、数据库系统的三级摸式结构

数据库系统的三级模式结构是指数据库系统是外模式、模式和内模式三级构成。

在这里插入图片描述

1)模式

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

2)外模式

外模式也称为子模式或用户模式,它是数据库用户能够看见和使用的局部数据的逻辑结构和特征的描述,是数据库用户的数据视图,是与某一个应用有关的数据的逻辑表示。

3)内模式

内模式也称为存储模式,一个数据库只有一个内模式。它是数据物理结构和存储方式的描述,是数据在数据库内部的组织方式。

1.3.3、数据库的二级映像功能与数据独立性

1)外模式/模式映象

模式描述的是数据全局逻辑结构外模式描述的是数据局部逻辑结构

同一个模式可以有任意多个外模式。对任意一个外模式,数据库系统都有一个外模式/模式映像,它定义了该外模式与模式之间的对应关系。

当模式发生改变时(例如增加新的关系、新的属性、改变属性的数据类型等)由数据库管理员对各个外模式/模式的映像做出相应的改变,可以使外模式保持不变。应用程序是依据数据的外模式编写的,从而应用程序不必修改,保证了数据与程序的逻辑独立性,简称数据的逻辑独立性。

2)模式/内模式映像

数据库中只有一个模式,也只有一个内模式,所以模式/内模式映像是唯一的,它定义数据全局逻辑结构与存储结构之间的对应关系

当模式发生改变时(例如增加新的关系、新的属性、改变属性的数据类型等)由数据库管理员对各个外模式/模式的映像做出相应的改变,可以使外模式保持不变。应用程序是依据数据的外模式编写的,从而应用程序不必修改,保证了数据与程序的逻辑独立性,简称数据的逻辑独立性。

2)模式/内模式映像

数据库中只有一个模式,也只有一个内模式,所以模式/内模式映像是唯一的,它定义数据全局逻辑结构与存储结构之间的对应关系

当数据库的存储结构改变时(例如选用了另一种存储结构)由数据库管理员对模式/内模式映像做出相应的改变,可以是模式保持不变,从而应用程序也不必改变。保证了数据与程序的物理独立性,简称数据的物理独立性。

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

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

相关文章

中科检测赴中科院广州电子CASAIM开展座谈会,围绕3D打印、三维扫描和精密测量展开深入交流

2月9日,中科检测技术服务(广州)股份有限公司(简称:中科检测)一行到访中科院广州电子技术有限公司,参观广东省增材制造工程实验室和三维扫描及精密测量重点实验室,就3D打印、三维扫描和精密测量相关技术内容…

NTP同步时钟为医院提供标准的时间信号

NTP同步时钟应用于城市重要公共领域,如车站、学校、医院、等。NTP同步时钟可提供准确的公众时间,为人们的日常生活提供便利,避免了因时钟不准确而带来的不便。NTP同步时钟采用智能模块化设计,与同类产品相比,更突出了安…

JavaScript Web API实战:7个小众技巧让你的网站瞬间提升用户体验

随着技术的日新月异,为开发人员提供了令人难以置信的新工具和API。但据了解,在100 多个 API中,只有5%被开发人员积极使用。 让我们来看看一些有用的Web API,它们可以帮助您将网站推向月球! 1、 截屏接口 Screen Capt…

ELK日志分析--Logstash

Logstash简介 Logstash安装 测试运行 配置输入和输出 使用Geoip过滤器插件增强数据编辑 配置接收 Beats 的输入 1.Logstash简介 Logstash管道具有两个必需元素input和output,以及一个可选元素filter。输入插件使用来自源的数据,过滤器插件根据你的…

shell的测试语句

一、shell的条件测试语句 在写shell脚本时,经常遇到的问题就是判断字符串是否相等,可能还要检查文件状态或进 行数字测试,只有这些测试完成才能做下一步动作。 1.1、shell脚本中的条件测试如下: 1、文件测试 2、字符串测试 3、数…

《计算机组成与系统结构(第二版) 裘雪红 李伯成 西安电子科技大学出版社》课后习题答案(带解析)(三)

声明:此系列答案配套《计算机组成与系统结构(第二版) 裘雪红 李伯成 西安电子科技大学出版社》一书相关内容。所有内容为博主个人编辑,仅作参考学习交流之用,转载请注明出处。如发现错误,请联系博主及时勘误…

java JMM 内存屏障

内存屏障的目的 每个CPU都会有自己的缓存(有的甚至L1,L2,L3),缓存的目的就是为了提高性能,避免每次都要向内存取。但是这样的弊端也很明显:不能实时的和内存发生信息交换,分在不同CPU执行的不同线程对同一…

基于SPI的增强式插件框架设计

很久之前,为了诊断线上的问题,就想要是能有工具可以在线上出问题的时候,放个诊断包进去马上生效,就能看到线上问题的所在,那该是多么舒服的事情。后来慢慢的切换到 java 领域后,这种理想也变成了现实&#…

【selenium 自动化测试】如何搭建自动化测试环境,搭建环境过程应该注意的问题

最近也有很多人私下问我,selenium学习难吗,基础入门的学习内容很多是3以前的版本资料,对于有基础的人来说,3到4的差别虽然有,但是不足以影响自己,但是对于没有学过的人来说,通过资料再到自己写的…

2023年PMP考试应该注意些什么?

首先注意(报考条件) 2023年PMP考试报名流程: 一、PMP英文报名: 英文报名时间无限制,随时可以报名,但有一年的有效期,所以大家尽量提前报名,在英文报名有效期内进行中文报名。 英…

深度卷积对抗神经网络 进阶 第三部分 GANs Unpaired Translation with Cycle GAN 模型

非配对的图像转换应用 Unpaired Image-to-Image Translation Unpaired image-to-image translation 主要用于学习两组图像之间的对应关系,检查和寻找两堆数据中的共同内容(content)以及每堆独有的特点(style)。而这个…

【Database-03】从 MySQL 迁移到 达梦数据库(DM 8)

1、环境 源数据库 MySQL 8.30 目标数据库 DM 8 操作系统 Centos 9 Steam 迁移工具 DM 数据迁移工具 (DM DTS) 2、开始迁移 2.1、打开DM数据迁移工具 在新建工程对话框中填写工程名和工程描述信息,点击【确定】按钮,成功添加了一个工程。 2.2、新建迁…

3年经验,3轮技术面+1轮HR面,拿下字节30k*16薪offer,这些自动化测试面试题值得大家借鉴

面试一般分为技术面和hr面,形式的话很少有群面,少部分企业可能会有一个交叉面,不过总的来说,技术面基本就是考察你的专业技术水平的,hr面的话主要是看这个人的综合素质以及家庭情况符不符合公司要求,一般来…

2023年,IT互联网还有发展前景吗?

不得不说,互联网在整个社会经济发展中扮演着不可或缺的角色;不仅自身的技术具有前沿性,也推动着其他行业进入数字化经济时代,让我们的工作生活变得更加便捷。 在“互联网”时代,每个服务行业都会利用大数据&#xff0…

SpringBoot入门(二)

这里写目录标题一、SpringBoot整合Junit1.1 搭建SpringBoot工程1.2 引入starter-test起步依赖1.3 编写类1.4 测试二、SpringBoot整合mybatis2.1 搭建SpringBoot工程2.2 引入mybatis起步依赖,添加驱动2.3 编写DataSource和MyBatis相关配置2.4 定义表和实体类2.5 编写…

Bootstrap入门到精通

文章目录前言一、Bootstrap是什么?二、Bootstrap安装方式一:将压缩包下载到本地引入使用方式二:使用Bootstrap官方cdn二.Bootstrap容器下面是屏幕宽度在不同大小时不同容器的显示状态三.Bootstrap栅格系统bootstrap网格系统有以下六个类网格系…

linux shell 入门学习笔记7 父子shell面试题

1. 不同的执行方式,不同的shell环境 每次调用bash/sh解释器执行脚本都会开启一个子shell,因此不保留当前shell变量,通过pstree命令检查进程树调用source是当前环境加载脚本,因此保留变量 例子: xiao123xiao123:~/Dow…

直播间的2个小感悟

我是卢松松,点点上面的头像,欢迎关注我哦! 在线人数固定 最近直播间出现了很多新面孔,有的是偶然刷到的,有的是关注互联网找到的。而直播间的人数一直没什么变化,卢松松在抖音直播较少,主播间…

开学第一周,超30所高校系主任选择与百度飞桨联办校赛

经历了一场特殊而漫长的假期,各地校园又恢复了往日的热闹,重新焕发出勃勃生机,师生们在一声声久别重逢的暖心问候中,迎来了2023年春季学期。 以赛促学蔚然成风 开学季是校内竞赛策划及启动的最佳时机之一,越来越多的老…

JVM17GUI工具

3. JVM 监控及诊断工具-GUI 篇 3.1. 工具概述 命令行工具或组合能帮您获取目标 Java 应用性能相关的基础信息,但它们存在下列局限: 1.无法获取方法级别的分析数据,如方法间的调用关系、各方法的调用次数和调用时间等&#xff0…