




已阅读5页,还剩11页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第1章 数据库概述本章教学目标 了解数据和信息的基本含义及它们之间的相互关系 了解数据管理技术的三个发展阶段。 理解数据库系统的组成和功能 理解数据库、数据库管理系统和数据库系统的概念及它们之间的联系 掌握数据库系统的三级模式结构及它们之间的两层映像 了解数据库技术新进展1.1 数据库管理技术的发展1.1.1 信息与数据 在数据处理中,我们最常用到的基本概念就是数据和信息,信息与数据有着不同的含义。1 .信息(Information) 信息的定义-信息是关于现实世界事物的存在方式或运动状态的反映的综合,具体说是一种被加工为特定形式的数据,但这种数据形式对接收者来说是有意义的,而且对当前和将来的决策具有明显的或实际的价值。 如“2000年硕士研究生将扩招30%”,对接受者有意义,使接受者据此作出决策。 信息的特征 信息源于物质和能量,它不可能脱离物质而存在,信息的传递需要物质载体,信息的获取和传递要消耗能量。v 如信息可以通过报纸、电台、电视、计算机网络进行传递。 信息是可以感知的,人类对客观事物的感知,可以通过感觉器官,也可以通过各种仪器仪表和传感器等,不同的信息源有不同的感知形式。v 如报纸上刊登的信息通过视觉器官感知,电台中广播的信息通过听觉器官感知。 信息是可存储、加工、传递和再生的。动物用大脑存储信息,叫做记忆。计算机存储器、录音、录像等技术的发展,进一步扩大了信息存储的范围。借助计算机,还可对收集到的信息进行取舍整理。 2. 数据 (Data) 数据的定义 数据是用来记录信息的可识别的符号,是信息的具体表现形式。 数据的表现形式 可用多种不同的数据形式表示同一信息,而信息不随数据形式的不同而改变。v 如“2000年硕士研究生将扩招30%”,其中的数据可改为汉字形式“两千年”、“百分之三十”。 数据的概念在数据处理领域中已大大地拓宽了,其表现形式不仅包括数字和文字,还包括图形、图象、声音等。这些数据可以记录在纸上,也可记录在各种存储器中。 3. 数据与信息的联系 数据是信息的符号表示或载体,信息则是数据的内涵,是对数据的语义解释。v 如上例中的数据2000、30%被赋予了特定的语义,它们就具有了传递信息的功能。 数据处理 数据处理是将数据转换成信息的过程,包括对数据的收集、存储、加工、检索、传输等一系列活动。其目的是从大量的原始数据中抽取和推导出有价值的信息,作为决策的依据。 可用下式简单的表示信息、数据与数据处理的关系: 信息=数据+数据处理 数据是原料,是输入,而信息是产出,是输出结果。“信息处理”的真正含义应该是为了产生信息而处理数据。1.1.2 数据库技术的产生与发展 数据处理的中心问题是数据管理。 数据管理是指对数据的组织、分类、编码、存储、检索和维护。 随着计算机硬件和软件的发展,数据管理经历了人工管理、文件系统和数据库系统三个发展阶段。1. 人工管理阶段(50年代中期以前) 这一阶段计算机主要用于科学计算。 硬件中的外存只有卡片、纸带、磁带,没有磁盘等直接存取设备。 软件只有汇编语言,没有操作系统和管理数据的软件。 数据处理的方式基本上是批处理。人工管理阶段的特点如下:1) 数据不保存 因为当时计算机主要用于科学计算,对于数据保存的需求尚不迫切。2) 系统没有专用的软件对数据进行管理 每个应用程序都要包括数据的存储结构、存取方法、输入方式等,程序员编写应用程序时,还要安排数据的物理存储,因此程序员负担很重。3) 数据不共享 数据是面向程序的,一组数据只能对应一个程序。 多个应用程序涉及某些相同的数据时,也必须各自定义,因此程序之间有大量的冗余数据。4) 数据不具有独立性 程序依赖于数据,如果数据的类型、格式、或输入输出方式等逻辑结构或物理结构发生变化,必须对应用程序做出相应的修改。在人工管理阶段,程序与数据之间的关系可用图1.1表示。 应用程序1数据集1应用程序2数据集2数据集3应用程序3图1.1 人工管理阶段2. 文件系统阶段(50年代后期至60年代中期) 这一阶段,计算机不仅用于科学计算,还大量用于信息管理。 大量的数据存储、检索和维护成为紧迫的需求。 硬件有了磁盘、磁鼓等直接存储设备。 在软件方面,出现了高级语言和操作系统。 操作系统中有了专门管理数据的软件,一般称为文件系统。 处理方式有批处理,也有联机处理。文件管理数据的特点如下:1) 数据以文件形式可长期保存下来 用户可随时对文件进行查询、修改和增删等处理。2) 文件系统可对数据的存取进行管理 程序员只与文件名打交道,不必明确数据的物理存储,大大减轻了程序员的负担。3) 文件形式多样化 有顺序文件、倒排文件、索引文件等,因而对文件的记录可顺序访问,也可随机访问,更便于存储和查找数据。 4) 程序与数据间有一定独立性 由专门的软件即文件系统进行数据管理,程序和数据间由软件提供的存取方法进行转换,数据存储发生变化不一定影响程序的运行。在文件系统阶段,程序与数据之间的关系可用图1.2表示。 文件n应用程序1应用程序2应用程序n文件1文件2文件系 统图1.2 文件系统阶段与人工管理阶段相比,文件系统阶段对数据的管理有了很大的进步,但一些根本性问题仍没有彻底解决,主要表现在以下三方面:1) 数据冗余度大 各数据文件之间没有有机的联系,一个文件基本上对应于一个应用程序,数据不能共享。2) 数据独立性低 数据和程序相互依赖,一旦改变数据的逻辑结构,必须修改相应的应用程序。 而应用程序发生变化,如改用另一种程序设计语言来编写程序,也需修改数据结构。3) 数据一致性差 由于相同数据的重复存储、各自管理,在进行更新操作时,容易造成数据的不一致性。 3.数据库系统阶段(60年代末开始) 60年代后期,计算机应用于管理的规模更加庞大,数据量急剧增加; 硬件方面出现了大容量磁盘,使计算机联机存取大量数据成为可能; 硬件价格下降,而软件价格上升,使开发和维护系统软件的成本增加。 文件系统的数据管理方法已无法适应开发应用系统的的需要。 为解决多用户、多个应用程序共享数据的需求,出现了统一管理数据的专门软件系统,即数据库管理系统。数据库系统管理数据的特点如下:1) 数据共享性高、冗余少 这是数据库系统阶段的最大改进,数据不再面向某个应用程序而是面向整个系统,当前所有用户可同时存取库中的数据。 这样便减少了不必要的数据冗余,节约存储空间,同时也避免了数据之间的不相容性与不一致性。2) 数据结构化 按照某种数据模型,将全组织的各种数据组织到一个结构化的数据库中,整个组织的数据不是一盘散沙,可表示出数据之间的有机关联。 例:要建立学生成绩管理系统,系统包含学生(学号、姓名、性别、系别、年龄)、课程(课程号、课程名)、成绩(学号、课程号、成绩)等数据,分别对应三个文件。 若采用文件处理方式,因为文件系统只表示记录内部的联系,而不涉及不同文件记录之间的联系,要想查找某个学生的学号、姓名、所选课程的名称和成绩,必须编写一段不很简单的程序来实现。 而采用数据库方式,数据库系统不仅描述数据本身,还描述数据之间的联系,上述查询可以非常容易地联机查到。3) 数据独立性高 数据的独立性是指逻辑独立性和物理独立性。 数据的逻辑独立性是指当数据的总体逻辑结构改变时,数据的局部逻辑结构不变,由于应用程序是依据数据的局部逻辑结构编写的,所以应用程序不必须修改,从而保证了数据与程序间的逻辑独立性。v 例如,在原有的记录类型之间增加新的联系,或在某些记录类型中增加新的数据项,均可确保数据的逻辑独立性。 数据的物理独立性是指当数据的存储结构改变时,数据的逻辑结构不变,从而应用程序也不必改变。v 例如,改变存储设备和增加新的存储设备,或改变数据的存储组织方式,均可确保数据的物理独立性。4) 有统一的数据控制功能 数据库为多个用户和应用程序所共享,对数据的存取往往是并发的,即多个用户可以同时存取数据库中的数据,甚至可以同时存取数据库中的同一个数据,为确保数据库数据的正确有效和数据库系统的有效运行,数据库管理系统提供下述四方面的数据控制功能。(1)数据的安全性(security)控制:防止不合法使用数据造成数据的泄露和破坏,保证数据的安全和机密;v 例如,系统提供口令检查或其他手段来验证用户身份,防止非法用户使用系统;也可以对数据的存取权限进行限制,只有通过检查后才能执行相应的操作。(2)数据的完整性(integrity)控制:系统通过设置一些完整性规则以确保数据的正确性、有效性和相容性。v 正确性是指数据的合法性,如年龄属于数值型数据,只能含0,1,9,不能含字母或特殊符号;v 有效性是指数据是否在其定义的有效范围,如月份只能用112之间的正整数表示;v 相容性是指表示同一事实的两个数据应相同,否则就不相容,如一个人不能有两个性别。(3)并发(concurrency)控制:多用户同时存取或修改数据库时,防止相互干扰而提供给用户不正确的数据,并使数据库受到破坏。(4)数据恢复(recovery):当数据库被破坏或数据不可靠时,系统有能力将数据库从错误状态恢复到最近某一时刻的正确状态。 数据库系统阶段,程序与数据之间的关系可用图1.3表示。 应用程序1应用程序2应用程序n数据库数 据 库管理系统 图1.3 数据库系统阶段1.2 数据库系统的结构 可以从多种不同的角度考查数据库系统的结构。v 从数据库管理系统的角度看,数据库系统通常采用三级模式结构,这是数据库系统内部的体系结构;v 从数据库最终用户的角度看,数据库系统的结构分为集中式结构、分布式结构和客户/服务器结构,这是数据库系统外部的体系结构。1.2.1 数据库系统的三级模式结构 模式(Schema)是数据库中全体数据的逻辑结构和特征的描述。v 例如:学生记录定义为(学号、姓名、性别、系别、年龄),称为记录型,v 而(001101,张立,男,计算机,20)则是该记录型的一个记录值。v 模式只是对记录型的描述,而与具体的值无关。 在数据库系统中,对于同一意义下的数据,如:学生数据,从计算机中处理的二进制表示到用户处理的诸如学生姓名、年龄等概念的数据之间,存在着许多抽象和转换。 通常DBMS把数据库从逻辑上分为三级,即外模式、模式和内模式,它们分别反映了看待数据库的三个角度。三级模式结构如图 1.4 所示。应用1应用2应用n子模式1子模式m子模式/模式映象模式模式/内模式映象内模式数据库 图 1.4 数据库系统的三级模式结构 1. 模式 模式(Schema)是数据库中全体数据的逻辑结构和特征的描述,又称概念模式或概念视图。视图可理解为一组记录的值,用户或程序员看到和使用的数据库的内容。 模式处于三级结构的中间层,它是整个数据库实际存储的抽象表示,也是对现实世界的一个抽象,是现实世界某应用环境(企业或单位)的所有信息内容集合的表示,也是所有个别用户视图综合起来的结果,所以又称用户共同视图。 它表示了数据库的整体数据。 DBMS 提供模式描述语言(模式 DDL)来定义模式。2. 外模式 又称子模式或用户模式或外视图,是三级结构的最外层,个别用户只对整个数据库的一部分感兴趣,所以外视图是个别用户看到和使用的数据库内容,因此也常把外视图称为用户数据库。 它由多种外记录值构成,这些记录值是概念视图的某一部分的抽象表示。即个别用户看到和使用的数据库内容,也称“用户DB”。 由多个“外记录值”组成,是概念视图的某一部分的抽象表示。 DBMS 提供子模式描述语言(子模式 DDL)来定义子模式。3. 内模式 又称存储模式或内视图,是三级结构中的最内层,也是靠近物理存储的一层,即与实际存储数据方式有关的一层,由多个存储记录组成,但并非物理层,不必关心具体的存储位置。 DBMS 提供内模式描述语言(内模式 DDL)来定义内模式。 在数据库系统中,外模式可有多个,而概念模式、内模式只能各有一个。 内模式是整个数据库实际存储的表示,而概念模式是整个数据库实际存储的抽象表示,外模式是概念模式的某一部分的抽象表示。三级结构的优点(1)保证数据的独立性。v 将模式和内模式分开,保证了数据的物理独立性;v 将外模式和模式分开,保证了数据的逻辑独立性。(2)简化了用户接口。v 按照外模式编写应用程序或敲入命令,而不需了解数据库内部的存储结构,方便用户使用系统。(3)有利于数据共享。v 在不同的外模式下可有多个用户共享系统中数据,减少了数据冗余。(4)利于数据的安全保密。v 在外模式下根据要求进行操作,不能对限定的数据操作,保证了其他数据的安全。4. 数据库系统的二级映象 数据库系统的三级模式是对数据的三个抽象级别,它使用户能逻辑地抽象地处理数据,而不必关心数据在计算机内部的存储方式,把数据的具体组织交给 DBMS 管理。 为了能够在内部实现这三个抽象层次的联系和转换,DBMS 在三级模式之间提供了二级映象功能。1) 模式/内模式映象 数据库中的模式和内模式都只有一个,所以模式/内模式映象是唯一的。 它确定了数据的全局逻辑结构与存储结构之间的对应关系。v 例如,存储结构变化时,模式/内模式映象也应有相应的变化,使其概念模式仍保持不变,即把存储结构的变化的影响限制在概念模式之下,这使数据的存储结构和存储方法较高的独立于应用程序,通过映象功能保证数据存储结构的变化不影响数据的全局逻辑结构的改变,从而不必修改应用程序,即确保了数据的物理独立性。2) 外模式/模式映象 数据库中的同一模式可以有任意多个外模式,对于每一个外模式,都存在一个外模式/模式映象。 它确定了数据的局部逻辑结构与全局逻辑结构之间的对应关系。v 例如,在原有的记录类型之间增加新的联系,或在某些记录类型中增加新的数据项时,使数据的总体逻辑结构改变,外模式/模式映象也发生相应的变化,v 这一映象功能保证了数据的局部逻辑结构不变,由于应用程序是依据数据的局部逻辑结构编写的,所以应用程序不必须修改,从而保证了数据与程序间的逻辑独立性。1.2.2 数据库系统的体系结构 单用户数据库系统 整个数据库系统都装在一台计算机上,为一个用户独占,不能共享。 主从式结构的数据库系统 一个主机带多个终端的多用户数据库系统。所有任务由主机完成,各用户通过终端并发地存取数据。 分布式数据库系统 逻辑上一致,但物理上分布。 客户-服务器结构的数据库系统 服务器中网络上用于执行数据库管理系统功能。客户端支持用户应用,将用户请求送给服务器。 浏览器-服务器结构(B/S结构) 用户通过Web浏览器去访问Internet上的信息,这些信息由Web服务器产生,每个Web服务器可以通过各种方式与数据库服务器相连,大量的数据实际存放在数据库服务器中。1.3 数据库、数据库管理系统与数据库系统 1.3.1 数据库(DB) 数据库是长期存储在计算机内的、统一管理的、相关的、有组织的可共享的数据集合。其主要特点是: 数据共享; 最小数据冗余; 支持数据完整性; 提高数据安全性; 具有较强数据独立性。1.3.2 数据库管理系统(DBMS) 数据库管理系统是对数据进行管理的大型系统软件,它是数据库系统的核心组成部分, 用户在数据库系统中的一切操作,包括数据定义、查询、更新及各种控制,都是通过DBMS进行的。 DBMS就是实现把用户意义下的抽象的逻辑数据处理转换成计算机中的具体的物理数据的处理软件,这给用户带来很大的方便。DBMS的主要功能: 1. 数据定义 DBMS提供数据定义语言DDL(Data Define Language),定义数据的模式、外模式和内模式三级模式结构,定义模式/内模式和外模式/模式二级映象,定义有关的约束条件,v 例如,为保证数据库安全而定义的用户口令和存取权限,为保证正确语义而定义完整性规则。2. 数据操纵 DBMS提供数据操纵语言DML(Data Manipulation Language)实现对数据库的基本操作,包括检索、插入、修改、删除等。 SQL语言就是DML的一种。3. 数据库保护功能 DBMS 对数据库的控制主要通过四个方面实现:v 数据的安全性控制v 数据的完整性控制v 多用户环境下的并发控制v 数据库的恢复 以确保数据正确有效和数据库系统的正常运行。4. 数据库的存储管理 存储和管理各种数据。5. 数据库的建立和维护 建立和维护数据库,包括数据输入、转换、数据库的转储与恢复,数据库和重新组织及性能监控等功能。1.3.3 数据库系统 数据库系统通常是指数据库和相应的软硬件系统。主要由数据(库)、用户、软件和硬件四部分组成。1.软件部分 包括操作系统、数据库管理系统、应用开发工具、应用程序。 DBMS是数据库系统的核心软件。数据库系统的各类人员对数据库的各种操作请求,都由DBMS完成,2.硬件部分 存储和运行数据库系统的硬件设备。包括CPU、内存、大容量的存储设备、外部设备等。3、人员部分 数据库管理员(Dadabase Administrator,简称DBA)DBA是指全面负责数据库系统的“管理、维护和正常使用的”人员,其职责如下:-模式定义;-内模式定义;-修改模式和内模式;-对访问数据库制授权;-完整性约束的说明。 系统分析员 应用程序员v 负责为终端用户设计和编制应用程序,以便终端用户对数据库进行存取操作。 终端用户(End User)v 主要是使用数据库的各级管理人员、工程技术人员、科研人员,一般为非计算机专业人员;1.4 数据库技术的发展1.4.1 层次数据库 层次模型是数据库系统中最早出现的数据模型,采用层次模型的数据库的典型代表是IBM公司的IMS(Information Management System)数据库管理系统。 现实世界中,许多实体之间的联系都表现出一种很自然的层次关系,如家族关系,行政机构等。 层次模型用一棵“有向树”的数据结构来表示各类实体以及实体间的联系。 下图是层次模型有向树的示意图。结点A为根结点,,F,G为叶结点,B,D为兄结点ABCDEF 层次模型有向树的示意图 层次模型的优缺点: 层次模型的优点主要有:(1)比较简单,只需很少几条命令就能操纵数据库,比较容易使用。(2)结构清晰,结点间联系简单。现实世界中许多实体间的联系本来就呈现出一种很自然的层次关系,v 如表示行政层次,家族关系很方便。(3)它提供了良好的数据完整性支持。层次模型的缺点主要有:(1)不能直接表示两个以上的实体型间的复杂的联系和实体型间的多对多联系,只能通过引入冗余数据或创建虚拟结点的方法来解决,易产生不一致性。(2)对数据的插入和删除的操作限制太多。(3)查询子女结点必须通过双亲结点。1.4.2 网状模型 20世纪70年代,数据系统语言研究会CODASYL(Conference On Data System Language)下属的数据库任务组DBTG(Data Base Task Group)提出了一个系统方案,DBTG系统,也称CODASYL系统,成为了网状模型的代表。 网状模型取消了层次模型的两个限制,两个或两个以上的结点都可以有多个双亲结点,则此时有向树变成了有向图,该有向图描述了网状模型。 如:学生和课程间的关系。一个学生可以选修多门课程,一门课程可以由多个学生选修。如下图所示: 学生课程 图:学生与课程的网状模型网状模型的优缺点 网状模型的优点主要有:(1)能更为直接地描述客观世界,可表示实体间的多种复杂联系。(2)具有良好的性能和存储效率 网状模型的缺点主要有(1)结构复杂,其DDL语言极其复杂。(2)数据独立性差,由于实体间的联系本质上是通过存取路径表示的,因此应用程序在访问数据时要指定存取路径。1.4.3 关系模型 关系模型是发展较晚的一种模型, 1970年美国IBM公司的研究员E.F.Codd首次提出了数据库系统的关系模型。v 他发表了题为“大型共享数据银行数据的关系模型”(A Relation Model of Data for Large Shared Data Banks),在文中解释了关系模型,定义了某些关系代数运算,研究了数据的函数相关性,定义了关系的第三范式,从而开创了数据库的关系方法和数据规范化理论的研究,v 他为此获得了1981年的图灵奖。v 此后许多人把研究方向转到关系方法上,陆续出现了关系数据库系统。v 1977年IBM公司研制的关系数据库的代表System R开始运行,其后又进行了不断的改进和扩充,出现了基于System R的数据库系统SQL/DB。 v 20世纪80年代以来,计算机厂商新推出的数据库管理系统几乎都支持关系模型,非关系系统的产品也都加上了关系接口。v 数据库领域当前的研究工作也都是以关系方法为基础。 关系数据库已成为目前应用最广泛的数据库系统,如现
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 汽修一级考试题库及答案
- 中医病因考试题目及答案
- 2025年广州中小学教师心理健康B证班结业考试题目及答案
- 检验技术员考试题及答案
- 科学数学考试卷子及答案
- 中国现代史考试题及答案
- 农民专业合作社与土地承包合同
- 规范税收缴纳承诺书8篇范文
- 合同管理标准化文件模板汇编
- 人员面试笔试题库及答案
- 2025年《燃烧与灭火》教案:从火灾的认识到灭火的技巧
- JJF1033-2023计量标准考核规范
- 人教版三年级下册数学计算题天天练附答案(30天)
- 2025森林抚育技术规程
- 病原微生物菌(毒)种和样本运输-项可霞
- 2024年03月中国工商银行湖南分行2024年度春季校园招考笔试历年参考题库附带答案详解
- 纪委谈话记录模板
- 统编版选择性必修上册7《兼爱》同步练习
- 2024建筑消防设施检测技术规范
- 《儿科病历书写规范》课件
- PAS 2050:2011-商品和服务在生命周期内的温室气体排放评价规范(中文)
评论
0/150
提交评论