没有合适的资源?快使用搜索试试~ 我知道了~
数据库系统基础知识.doc
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 4 浏览量
2022-07-13
10:00:53
上传
评论
收藏 255KB DOC 举报
温馨提示
试读
36页
数据库系统基础知识.doc
资源推荐
资源详情
资源评论
1 / 36
数据库系统概论
本章目的在于使读者对数据库系统的基本知识能有一个较为全面的了解,为今后的学习和
工作打下基础。本章重点介绍了有关数据库结构和数据库系统组织的基本知识和基本概
念,以与常见的三种类型的数据库系统的特点。重点介绍关系数据库的有关知识。
1.1 数据管理技术发展史
随着生产力的不断发展,社会的不断进步,人类对信息的依赖程度也在不断地增加。数据
作为表达信息的一种量化符号,正在成为人们处理信息时重要的操作对象。所谓数据处理
就是对数据的收集、整理、存储、分类、排序、检索、维护、加工、统计和传输等一系列
工作全部过程的概述。数据处理的目的就是使我们能够从浩瀚的信息数据海洋中,提取出
有用的数据信息,作为我们工作、生活等各方面的决策依据。数据管理则是指对数据的组
织、编码、分类、存储、检索和维护,它是数据处理的一个重要内容中心。数据处理工作
由来以久,早在1880年美国进行人口普查统计时,就已采用穿孔卡片来存储人口普查数
据,并采用机械设备来完成对这些普查数据所进行的处理工作。电子计算机的出现以与其
后其硬件、软件的迅速发展,加之数据库理论和技术的发展,为数据管理进入一个革命性
阶段提供有力的支持。根据数据和应用程序相互依赖关系、数据共享以与数据的操作方
式,数据管理的发展可以分为三个具有代表性的阶段,即人工管理阶段、文件管理阶段和
数据库管理阶段。
[1]人工管理阶段
这一阶段发生于六十年代以前,由于当时计算机硬件和软件发展才刚刚起步,数据管理中
全部工作,都必须要由应用程序员自己设计程序完成去完成。由于需要与计算机硬件以与
各外部存储设备和输入输出设备直接打交道,程序员们常常需要编制大量重复的数据管理
基本程序。数据的逻辑组织与它的物理组织基本上是一样的,因此当数据的逻辑组织、物
理组织或存储设备发生变化时,进行数据管理工作的许多应用程序就必须要进行重新编
制。这样就给数据管理的维护工作带来许多困难。并且由于一组数据常常只对应于一种应
用程序,因此很难实现多个不同应用程序间的数据资源共享。存在着大量重复数据,信息
资源浪费严重。
[2]文件管理阶段
这一阶段发生于六十年代,由于当时计算机硬件的发展,以与系统软件尤其是文件系统
的出现和发展,人们开始利用文件系统来帮助完成数据管理工作,具体讲就是:数据以
多种组织结构(如顺序文件组织、索引文件文件组织和直接存取文件组织等)的文件形
式保存在外部存储设备上,用户通过文件系统而无需直接与外部设备打交道,以此来完
成数据的修改、插入、删除、检索等管理操作;使用这种管理方式,不仅减轻进行数据
管理的应用程序工作量,更重要地是,当数据的物理组织或存储设备发生变化时,数据
的逻辑组织可以不受任何影响,从而保证了基于数据逻辑组织所编制的应用程序也可以
不受硬件设备变化的影响。这样就使得程序和数据之间具有了一定的相互独立性。
但由于数据文件的逻辑结构完全是根据应用程序的具体要求而设计,它的管理与维护完全
是由应用程序本身来完成,因此数据文件的逻辑结构与应用程序密切相关,当数据的逻辑
结构需要修改时,应用程序也就不可避免地需要进行修改;同样当应用程序需要进行变动
时,常常又会要求数据的逻辑结构进行相应的变动。在这种情况下,数据管理中的维护工
作量也是较大的。更主要的是由于采用文件的形式来进行数据管理工作,常常需要将一个
完整的、相互关联的数据集合,人为地分割成若干相互独立的文件,以便通过基于文件系
统的编程来实现来对它们的管理操作。这样做同样会导致数据的过多冗余和增加数据维护
工作的复杂性。例如人事部门、教务部门和医务部门对学生数据信息的管理,这三个部门
中有许多数据是一样的,如XX、年龄、性别等,由于是各部门均是根据自己的要求,建立
各自的数据文件和应用程序,这样不仅造成了大量的一样数据重复存储,而且在修改时,
常常需要同时修改三个文件中的数据项,如修改学生年龄,此外若需要增加一个描述学生
的数据项,如通讯地址,那么所有的应用程序就必须都要进行相应的修改。除此之外,采
用文件系统来帮助进行数据管理工作,在数据的安全和保密等方面,也难以采取有效的措
施加以控制。
[3]数据库管理阶段
1在不断改进和完善文件系统的过程中,从六十年代后期开始,人们逐步研究和发展
了以数据的统一管理和数据共享为主要特征的数据库系统。即在数据在统一控制之下,为
尽可能多的应用和用户服务,数据库中的数据组织结构与数据库的应用程序相互间有较大
的相对独立性等。与以往前数据管理方法和技术相比,利用数据库系统来进行数据管理工
作具有以下三个显著特点:
(1)从整体角度组织数据
数据库系统与文件系统的最大差别就在于前者在描述数据时,不仅仅是对数据本身进行描
述,而且对数据之间的相互联系也进行了描述。因此在组织数据时是从一个相对较高的整
体角度进行的,而不是仅仅局限于个别的数据管理应用场合。如前面提到的人事部门、教
务部门和医务部门对学生数据的管理工作,在利用数据库系统来进行管理时,若从整体考
虑,其数据的组织结构如图1.1所示。
图1.1 学生信息数据组织结构
采用这种数据组织不仅可以有效地解决了文件系统的数据组织中所存在的数据冗余以与数
据一致性维护的问题。更主要的是它可以使人们从更高的全局角度出发,合理地组织数
据,从而有利于更大范围内的数据资源的共享,提高信息的使用效率。
学生信息数据公用部分
人事部门学生数据专用部分
教务部门学生数据专用部分
医务部门学生数据专用部分
3 / 36
(2)数据可为多个应用服务
正因为数据库中的数据是从整体角度进行组织的,因此,数据库中所存储的数据往往就不
仅局限于只为一二个应用提供服务,而是在更大范围内为仅可能多的应用提供服务,如图
1.1所示的一个数据库中所存储的数据,就至少可以为三个部门的应用提供服务。而实际
上如图1.1所示的数据组织结构仅仅只是一个学校数据管理数据库中的一小部分。与此同
时由于数据库系统是以多级(层)组织模式对数据进行组织的,各级(层)模式之间的映
射是由数据库系统自己完成的,这就使得数据与程序之间可以具有较高的物理和逻辑相对
独立性。正是这一点,给数据库中的数据为多个应用提供服务奠定了基础。事实上数据库
的规模越大,所能够提供的应用服务就可以越多,也就越能体现出数据库在数据管理中的
优势。当然这只是相对而言,随着数据库中数据规模的扩大,数据库应用系统的制作和维
护的工作也在迅速增加。
(3)有一个数据库系统的管理软件
任何数据库系统都包含一个管理软件,即数据库系统的管理软件,通常又称为数据库管理
系统,它负责统一管理数据库系统中所有数据资源,是数据库系统与用户应用之间的接
口,通过它,用户可以不必要了解过多的计算机硬件、软件和数据库本身许多专业知识,
更不用去了解数据库系统是如何完成数据管理工作的具体细节,如文件如何打开、关闭、
读、写等等,就可以通过编写一些较为简单数据库应用程序,很方便地完成在较高级别逻
辑组织基础上的数据管理工作。除此之外,数据库管理系统还负责完成在对数据库进行并
发访问时,保证数据一致性的并发控制工作;保证数据安全性的访问控制工作;以与在数
据库系统出现故障时,提供保证数据一致性和完整性的恢复机制等诸多数据库系统本身的
各种管理控制工作。因此这里也可以看出,数据库管理系统功能的强弱与其各项性能指标
的好坏,是衡量数据库系统质量的一个极其重要的因素。
利用数据库系统进行数据管理工作,不仅可以保证数据的物理组织结构和存储设备与数据
库应用程序之间保持相互独立性;同时也可以保证数据的逻辑组织结构与数据库应用程序
之间保持最大可能的相互独立性,即当数据的逻辑组织结构发生变化时,数据库应用程序
的变动被限制在最小的范围内。由此可大大地减少数据库应用程序的开发与维护的工作
量。
在数据库管理阶段,根据数据库系统本身所支持的数据模型的特点与所采用的相应数据库
系统技术,可以认为数据库管理到目前为止已发展经历了三代,即层次网状模型代、关系
模型代和面向对象模型代。
(1)层次网状模型代:流行于六十至七十年代,在这一代中的数据库系统所支持的数据模
型均是层次模型或网状模型。世界上第一个数据库系统是于1964年由美国通用电气公司开
发成功的IDS(Integrated Data Store),它就是基于网状模型的数据库系统。IBM公司
于六十年代末推出了第一个商品化的层次数据库系统IMS(Information Management
Sytem),它们的出现与应用为数据库技术的发展奠定了基础。
(2)关系模型代:流行于七十至八十年代,在这一代中的数据库系统所支持的数据的数据
模型均是关系模型。以关系(表)形式组织数据。1970年Codd提出了关系数据模型,由于
其具有严格的数学基础,抽象级别较高,且简单清晰,便于理解应用。到了七十年代末,
出现了不少关系数据库系统,其中具有代表性应首推IBM公司推出的SQL/DS和DB2两个商品
化关系数据库系统。进行八十年代以后,关系数据库系统已成为数据库系统发展的主流,
几乎所有新推出的数据库系统产品都是关系型的,它们中不仅有用于大型机和小型机数据
库产品,而且有可用于微机的数据库产品。市场上开始出现关系数据库的系列产品,这其
中发行量较大且在我国用得较多的有Oracle、Sybase、Sysbase、Informix、FoxPro等。
随着微机和计算机网络的广泛普与和应用,分布式数据库系统在八十年代后期,开始得到
很大发展。其理论和技术日趋成熟。目前几乎所有分布式数据库系统均是关系型的,而且
几乎所有主要关系数据库系统均已被扩充为分布式数据库系统。
(3)面向对象代:开始九十年代,在这一代中的数据库系统支持面向对象的数据模型。它
是数据库技术与面向对象程序设计方法相结合的产物。作为新一代数据库系统,现在已有
了一些商品化系统。但其具体应用尚不多。
1.2 数据库系统
本节主要介绍有关数据库结构和数据库系统组织的一些基本知识和概念,使读者对数据库
系统的内涵有一个较为清楚的认识。
1.2.1 数据库系统概念
由于数据库系统是一个由许多基本概念、技术方法和其应用对象所组成的复杂的有机整
体。很难用一两句话将其描述清楚。但为了使读者对它有一个总体的了解,首先这里我们
试着给出一个关于数据库系统的定义,即数据库系统中的数据库是一个已被规格化和结构
化且相互关联的数据集合,这些数据中不存在有害的或无意义的冗余;数据的组织与存储
结构与使用这些数据的程序相互独立;数据库中的数据可同时为多个应用服务;数据库中
的数据定义、输入、修改和检索等所有操作均是按一种公用的且可控的方式进行。根据这
一数据库定义以与实际应用的具体数据库系统的情况,我们可以认为一个数据库系统实际
上是由三部分内容组成,它们是数据库、多种应用和数据库管理系统。这三部分之间的相
互关系如图1.2所示。
(1)数据库:相互关联的且具有最小冗余的数据在其中按照一定物理组织结构存放,并且
从用户和数据库管理系统角度来看,这些数据又是按一定逻辑结构组织的。这种物理组织
结构和逻辑组织结构在最大程度上与用户所编制的应用程序相互独立。
(2)多种应用:数据库中的数据,在数据库管理系统的控制与管理之下,可以同时为多种
不同内容的应用提供服务,即可以为多个不同目的用户服务,各用户所操作使用的数据可
以是相互交叉的。用户的操作方式既可以按以数据输入/输出和数据维护为主的数据流量
较大的批处理方式进行;也可以按以查询为主的数据流量较小的联机处理方式进行,必要
时还可以通过编程来完成对数据库中数据的各种操作。
5 / 36
(3)数据库管理系统:它一方面负责对数据库中的数据进行管理和维护;一方面为用户操
作数据库中的数据提供一种公用的操作方法,接收用户的操作命令,帮助完成有关的对数
据库的操作并保障数据库的安全。
根据对数据库的定义以与数据库系统基本组成与作用的描述,我们认为一个的数据库系统
应该具有的以下五个基本特点:
[1]由于数据库系统是从整体角度考虑数据的组织,因此它必须有能力描述能够反映客观
事物与其相互联系的复杂数据模型,使用它能够对数据本身与相互间的各种关系进行充分
描述,这也是人们为什么要采用数据库系统来进行数据管理的主要原因之一。目前数据库
系统共提供了四种数据模型,它们是层次数据模型、网状数据模型、关系数据模型和对象
数据模型,一种类型数据库系统通常只提供上述其中一种数据模型描述方法,即只支持其
中一种数据模型的数据逻辑组织结构。
图1.2 数据库系统组成
[2]数据库中数据的独立性。为了说明这一点,首先我们介绍两个概念,(1)数据在物理
存储设备上的组织结构被称为数据的物理组织;(2)数据在用户或应用程序面前所表现
出的组织结构被称为数据的逻辑组织;一种数据的逻辑组织,可以采用不同的物理组织来
实现,物理组织的好坏影响着系统的性能和效率。在运行阶段中,由于性能的要求或存储
设备的改变,从而引起数据物理组织的改变,这种改变称为数据的再组织。用户在编制应
用程序时,则是根据数据的逻辑组织对数据进行操作的。因此数据物理组织的变化,不会
影响数据的逻辑组织,因而也就不会影响已有的应用程序,这种情况就被称为数据的物理
独立性;而数据的逻辑独立性是指当数据的逻辑组织发生变化时,如数据模型中增加了新
的记录类型,某一记录类型中增加了新的数据项等,原有应用程序的执行不受影响或影响
最小。数据的独立性,包括物理和逻辑的独立性,都是由数据库管理系统进行维护的。
[3]数据共享,由于数据库是从整体的角度对数据进行组织的,并在保证数据一致性的情
形之下,使数据库中的数据为尽可能多的用户提供应用服务。这些用户所使用的数据可以
是交叉的,即数据可以共享。如果数据不能共享,数据库中则必然会出现大量的冗余数
据,这样不仅造成存储空间的浪费,更主要的是由此可能带来数据不一致的隐患。
[4]数据库系统的安全可靠与完整,一个数据库系统的可靠性体现在它的软件系统运行故
障率很小以与在数据库系统由于各种意外而出现故障时,数据库中的数据的损失最小;安
全性是指数据库系统对其所存储的数据的保护能力,能够有效地防止数据有意无意地泄露
或篡改,控制数据的授权访问等。而数据库系统的完整性则是指在多用户操作数据情况
下,数据能够保持一致性。这些特性可以从以下几个方面进行说明:
用户1
用户2
....
用户n
数据库管理系统
数据库
剩余35页未读,继续阅读
资源评论
智慧安全方案
- 粉丝: 3645
- 资源: 59万+
下载权益
C知道特权
VIP文章
课程特权
开通VIP
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功