数据库应用程序开发课件_第1页
数据库应用程序开发课件_第2页
数据库应用程序开发课件_第3页
数据库应用程序开发课件_第4页
数据库应用程序开发课件_第5页
已阅读5页,还剩92页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第8章数据库应用程序开发12021精选ppt数据库应用程序的体系结构主机集中型结构文件型服务器结构二层客户/服务器(C/S)结构三层客户/服务器结构返回首页22021精选ppt主机集中型结构主机集中型结构的数据库应用系统一般在一台主机(大型计算机或小型计算机)带多台终端的环境下运行,这种结构在20世纪60~70年代比较盛行。在这种结构的数据库应用程序中,数据库的存储、计算、读取与应用程序的执行,全部集中在后端的主机上执行。用户通过前端的终端输入信息传至主机处理,主机处理完成后将处理的结果返回到前端的终端显示给用户。其结构如图所示。32021精选ppt返回本节42021精选ppt

文件型服务器结构到了20世纪80年代,随着苹果计算机、IBM个人计算机的诞生,其开放性的结构、日渐平易近人的价格,以及愈来愈强的执行性能,已为一般企业所能负担,而文件型数据库应用程序也就在此时趁势崛起。在文件型数据库应用程序中,数据存放在文件型数据库中,如早期的dBaseIII,到今天的Access,就是一些拥有高知名度的文件型数据库。存放数据库文件的服务器作为文件服务器使用,应用程序的数据运算和处理逻辑则存放在前端的工作站中。其体系结构如图9-3所示。52021精选ppt62021精选ppt例如:在数据库中有一客户表,共有10,000条客户资料。现假设想找出客户编号为00001的客户信息,则文件型数据库应用程序处理这个请求的方法是:(1)先把这10,000条客户数据从文件服务器通过局域网传至前端工作站。(2)前端工作站再从这10,000条客户数据中查找客户编号为00001客户信息。(3)查询作业结束后,再把这10,000条记录返回到文件服务器。返回本节72021精选ppt二层客户/服务器(C/S)结构为了解决费用和性能的矛盾,客户/服务器(C/S)结构就应运而生了。该结构是由一组性能良好且稳定的主机来做数据库服务器,然后连上一群充当客户机的工作站而成。在这种结构中,数据库的管理由数据库服务器完成,应用程序的数据处理,如数据访问规则、业务规则、数据合法性校验等则可能有两种情况:一是全部由客户机来完成,客户机向服务器传送的是结构化查询语言SQL;二是由客户机和服务器共同来承担,程序处理一部分在客户端以程序代码来实现,一部分在服务器端以数据库中的触发器或存储过程实现,客户机向服务器传送的是SQL或要进行处理的参数。其系统结构如图9-4所示82021精选ppt图9-4客户/服务器结构92021精选ppt以同样要从10,000条客户数据记录中,找出客户编号为00001的客户信息,客户/服务器结构对这种请求的处理方式是:(1)前端客户机向后端数据库服务器发出请求。(2)数据库服务器在收到前端客户机的请求后,自客户表中找出编号为00001的客户信息。(3)数据库服务器再把查询到的结果传至前端客户机。102021精选ppt由于这种通信方式简单,软件开发起来容易,现在很多的应用软件都是基于这种二层的客户/服务器模式的,但这种结构模式的软件存在以下问题:伸缩性差。性能较差。重用性差。移植性差。返回本节112021精选ppt三层客户/服务器结构分离的目的是使客户机上的所有处理过程不直接涉及到数据库管理系统,分离的结果将应用程序在逻辑上分为三层:用户服务层:提供信息浏览和服务定位。主要是实现用户界面,并保证用户界面的友好性、统一性。业务处理层:实现数据库的存取及应用程序的商业逻辑计算。数据服务层:实现数据定义、存储、备份和检索等功能,主要由数据库系统实现。122021精选ppt图9-5三层客户/服务器结构132021精选ppt三层结构的系统具有如下特点:(1)业务逻辑放置在中间层可以提高系统的性能,使中间层业务逻辑处理与数据层的业务数据紧密结合在一起,而无需考虑客户的具体位置。(2)添加新的中间层服务器,能够满足新增客户机的需求,大大地提高了系统的可伸缩性。(3)将业务逻辑置于中间层,从而使业务逻辑集中到一处,便于整个系统的维护和管理及代码的复用。142021精选ppt一个基于Web的应用程序在逻辑上可能包含如下几层:1层,由Web浏览器实现的一个客户层的界面。2层,由Web服务器实现的一个中间层的任务分配机制。3层,由一些服务器端脚本实现的中间层服务。4层,由关系数据库实现的数据层存储机制。152021精选ppt图9-6互联网应用程序结构返回本节162021精选ppt数据库与应用程序的接口ODBCJDBC返回首页172021精选pptODBC(OpenDatabaseConnectivity,开放数据库互连)是微软公司开放服务结构(WOSA,WindowsOpenServicesArchitecture)中有关数据库的一个组成部分,它建立了一组规范,并提供了一组对数据库访问的标准API(应用程序编程接口)。这些API利用SQL来完成其大部分任务。ODBC本身也提供了对SQL语言的支持,用户可以直接将SQL语句送给ODBC。

一个基于ODBC的应用程序对数据库的操作不依赖任何DBMS,不直接与DBMS打交道,所有的数据库操作由对应的DBMS的ODBC驱动程序完成。也就是说,不论是FoxPro、Access,MYSQL还是Oracle数据库,均可用ODBCAPI进行访问。由此可见,ODBC的最大优点是能以统一的方式处理所有的数据库。

182021精选pptODBC的体系结构ODBC的体系结构如图9-7所示,它由数据库应用程序、驱动程序管理器、数据库驱动程序和数据源四部分组成。(1)数据库应用程序。(2)驱动程序管理器(3)数据库驱动程序。(4)ODBC数据源。192021精选ppt202021精选ppt2.管理数据源ODBC驱动程序管理器可以建立、配置或删除命名的数据源,下面以配置OracleODBC数据源为例讲解配置数据源的方法。其步骤如下:(1)启动ODBC驱动程序管理器。选择“我的电脑”→“控制面板”→“管理工具”,双击“数据源(ODBC)”图标打开ODBC数据源(驱动程序)管理器,如图所示。212021精选ppt使用ODBC连接数据库时,提供了3种DSN:用户DSN、系统DSN和文件DSN.这里选择系统DSN。222021精选ppt图9-8“系统DSN”选项卡(2)选择ODBC驱动程序。单击“添加(D)…”按钮,将弹出如下图所示的对话框,选择数据源驱动程序“OracleinOraClient10g_home01”(不同的安装可能有不同的名称),单击“完成”按钮。232021精选ppt(3)输入ODBC数据源名称,选择数据源的SQL服务器。如下图所示,将数据源命名为SelBook,TNS服务名选择为ORCL(第二章中客户端安装中的NET服务配置),用户名输入BookSys,单击OK按钮,完成OracleODBC的配置工作。242021精选ppt数据库设计数据库设计概述需求分析概念结构设计逻辑结构设计数据库的物理设计数据库实施数据库运行与维护252021精选ppt数据库设计概述数据库设计是指对一个给定的应用环境,构造最优的、最有效的数据库模式,建立数据库及其应用系统,使之能够高效率地存取数据,满足各种用户的应用需求。数据库设计通常是在一个通用的DBMS支持下进行的。数据库的设计工作通常分阶段进行,不同的阶段完成不同的设计内容。数据库规范设计方法通常将数据库的设计分为6个阶段,如图8-1所示。返回首页262021精选ppt272021精选ppt数据库的设计分为6个阶段(1)需求分析。收集和分析用户对系统的信息需求和处理需求,得到设计系统所必须的需求信息,建立系统说明文档。(2)概念结构设计。概念结构设计是整个数据库设计的关键。它通过对用户的需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型。(3)逻辑结构设计。在概念模型的基础上导出一种DBMS支持的逻辑数据库模型(如关系型、网络型或层次型),该模型应满足数据库存取、一致性及运行等各方面的用户需求。282021精选ppt(4)物理结构设计。从一个满足用户需求的已确定的逻辑模型出发,在限定的软、硬件环境下,利用DBMS提供的各种手段设计数据库的内模式,即设计数据的存储结构和存取方法。(5)数据库实施。运用DBMS提供的数据语言及宿主语言,根据逻辑设计和物理设计的结果建立数据库,编制与调试应用程序,组织数据入库,并进行试运行。(6)数据库运行和维护。292021精选ppt返回本节302021精选ppt需求分析需求分析的任务需求分析的基本步骤需求分析应用实例返回首页312021精选ppt需求分析的任务根据需求分析的目标,需求分析这一阶段的任务主要有两项:(1)确定设计范围。通过详细调查现实世界要处理的对象(组织、部门和企业等),弄清现行系统(手工系统或计算机系统)的功能划分、总体工作流程,明确用户的各种需求。(2)数据收集与分析。需求分析的重点是在调查研究的基础上,获得数据库设计所必须的数据信息。返回本节322021精选ppt需求分析的基本步骤1.调查与初步分析用户的需求,确定系统的边界2.分析和表达用户的需求332021精选ppt1.调查与初步分析用户的需求,确定系统的边界(1)首先调查组织机构情况。(2)然后调查各部门的业务活动情况。(3)在熟悉了业务活动的基础上,协助用户明确对新系统的各种要求,包括信息要求、处理要求、安全性与完整性要求,这是调查的又一个重点。(4)最后对前面调查的结果进行初步分析,确定新系统的边界,确定哪些功能由计算机完成或将来由计算机完成,哪些活动由人工完成。342021精选ppt352021精选ppt2.分析和表达用户的需求(1)数据流图。数据流图(DataFlowDiagram,简称DFD)是一种最常用的结构化分析工具,它用图形的方式来表达数据处理系统中信息的变换和传递过程。如图8-4所示,数据流图有4种基本符号。362021精选ppt372021精选ppt(2)数据字典。1)数据项条目:数据项是不可再分的数据单位,它直接反映事物的某一特征。2)数据结构条目:反映了数据之间的组合关系。3)数据流条目:数据流是数据结构在系统内传输的路径。4)数据文件条目:数据文件是数据项停留或保存的地方,也是数据流的来源和去向之一。5)处理过程条目。返回本节382021精选ppt需求分析应用实例现要开发高校图书管理系统。经过可行性分析和初步的需求调查,确定了系统的功能边界,该系统应能完成下面的功能:(1)读者注册。(2)读者借书。(3)读者还书。(4)图书查询。392021精选ppt1.数据流图通过对系统的信息及业务流程进行初步分析后,首先抽象出该系统最高层的数据流图,即把整个数据处理过程看成是一个加工的顶层数据流图,如图8-5所示。402021精选ppt412021精选ppt顶层数据流图反映了图书管理系统与外界的接口,但未表明数据的加工要求,需要进一步细化。根据前面图书管理系统功能边界的确定,再对图书管理系统顶层数据流图中的处理功能做进一步分解,可分解为读者注册、借书、还书和查询四个子功能,这样就得到了图书管理系统的第0层数据流图,如图8-6所示。422021精选ppt432021精选ppt从图书管理系统第0层数据流图中可以看出,在图书管理的不同业务中,借书、还书、查询这几个处理较为复杂,使用到不同的数据较多,因此有必要对其进行更深层次的分析,即构建这些处理的第1层数据流图。下面的图8-7分别给出了借书、还书、查询子功能的第1层数据流图。442021精选ppt452021精选ppt462021精选ppt472021精选ppt2.数据字典(1)数据项描述。数据项名称:借书证号别名:卡号含义说明:惟一标识一个借书证类型:字符型长度:20482021精选ppt(2)数据结构描述。名称:读者类别含义说明:定义了一个读者类别的有关信息组成结构:类别代码+类别名称+可借阅数量+借阅天数+超期罚款额名称:读者含义说明:定义了一个读者的有关信息组成结构:姓名+性别+所在部门+读者类型名称:图书含义说明:定义了一本图书的有关信息组成结构:图书编号+图书名称+作者+出版社+价格492021精选ppt(3)数据流(非数据项)说明。数据流名称:借书单含义:读者借书时填写的单据来源:读者去向:审核借书数据流量:250份/天组成:借书证编号+借阅日期+图书编号数据流名称:还书单含义:读者还书时填写的单据来源:读者去向:审核还书数据流量:250份/天组成:借书证编号+还书日期+图书编号502021精选ppt(4)数据存储说明。数据存储名称:图书信息表含义说明:存放图书有关信息组成结构:图书+库存数量说明:数量用来说明图书在仓库中的存放数数据存储名称:读者信息表含义说明:存放读者的注册信息组成结构:读者+卡号+卡状态+办卡日期说明:卡状态是指借书证当前被锁定还是正常使用数据存储名称:借书记录含义说明:存放读者的借书、还书信息组成结构:卡号+书号+借书日期+还书日期说明:要求能立即查询并修改512021精选ppt(5)处理过程说明。处理过程名称:审核借书证输入:借书证输出:认定合格的借书证加工逻辑:根据读者信息表和读者借书证,如果借书证在读者信息表中存在并且没有被锁定,那么借书证是有效的借书证,否则是无效的借书证。返回本节522021精选ppt概念结构设计概念结构设计的方法和步骤局部视图设计视图的集成概念结构设计实例返回首页532021精选ppt概念结构设计的方法和步骤1.自顶向下设计法2.自底向上设计法3.由里向外设计法4.混合策略设计法542021精选ppt552021精选ppt返回本节562021精选ppt局部视图设计局部视图设计是根据系统的具体情况,在多层的数据流图中选择一个适当层次的数据流图,作为设计分E-R图的出发点,并让数据流图中的每一个部分都对应一个局部应用。选择好局部应用之后,就可以对每个局部应用逐一设计分E-R图了。局部E-R图的设计分为如下的几个步骤,如图8-10所示。572021精选ppt582021精选ppt1.确定实体类型和属性实体和属性之间没有严格的区别界限,但对于属性来讲,可以用下面的两条准则作为依据:(1)作为属性必须是不可再分的数据项,也就是属性中不能再包含其他的属性。(2)属性不能与其他实体之间具有联系。592021精选ppt2.确定实体间的联系依据需求分析结果,考察任意两个实体类型之间是否存在联系,若有,则确定其类型(一对一,一对多或多对多),接下来要确定哪些联系是有意义的,哪些联系是冗余的,并消除冗余的联系。所谓冗余的联系是指无意义的或可以从其他联系导出的联系。602021精选ppt3.画出局部E-R图确定了实体及实体间的联系后,可用E-R图描述出来。形成局部E-R图之后,还必须返回去征求用户意见,使之如实地反映现实世界,同时还要进一步规范化,以求改进和完善。每个局部视图必须满足:(1)对用户需求是完整的。(2)所有实体、属性、联系都有惟一的名字。(3)不允许有异名同义、同名异义的现象。(4)无冗余的联系。612021精选ppt返回本节622021精选ppt视图的集成各个局部视图建立好后,还需要对它们进行合并,集成为一个整体的数据概念结构,即总E-R图。集成局部E-R图型,设计全局E-R模型的步骤如图8-12所示。632021精选ppt642021精选ppt1.合并局部E-R图,生成初步E-R图(1)属性冲突。(2)命名冲突。(3)结构冲突。652021精选ppt2.修改和重构初步E-R图,消除冗余,生成基本E-R图(1)用分析的方法消除冗余。分析方法是消除冗余的主要方法。(2)用规范化理论消除冗余。662021精选ppt672021精选ppt682021精选ppt692021精选ppt返回本节702021精选ppt概念结构设计实例1.标识图书管理系统中的实体和属性参照数据字典中对数据存储的描述,可初步确定三个实体的属性为:读者:{卡号,姓名,性别,部门,类别、办卡日期,卡状态}图书:{书号,书名,作者,价格,出版社,库存数量}借还记录:{卡号,书名,借书日期,还书日期}其中有下划线的属性为实体的码。712021精选ppt2.确定实体间的联系722021精选ppt732021精选ppt返回本节742021精选ppt逻辑结构设计逻辑结构设计的任务和步骤概念模型转换为一般的关系模型逻辑结构设计综合实例将一般的关系模型转换为oracle下的关系模型数据模型的优化设计用户外模式返回首页752021精选ppt逻辑结构设计的任务和步骤逻辑结构设计的主要目标是将概念结构转换为一个特定的DBMS可处理的数据模型和数据库模式。该模型必须满足数据库的存取、一致性及运行等各方面的用户需求。逻辑结构的设计过程如图8-18所示。762021精选ppt772021精选ppt从图8-18中可以看出,概念模型向逻辑模型的转换过程分为3步进行:(1)把概念模型转换为一般的数据模型。(2)将一般的数据模型转换成特定的DBMS所支持的数据模型。(3)通过优化方法将其转化为优化的数据模型。返回本节782021精选ppt概念模型转换为一般的关系模型1.实体的转换规则将E-R图中的每一个常规实体转换为一个关系,实体的属性就是关系的属性,实体的码就是关系的码。2.实体间联系的转换规则(1)一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端所对应的关系模式合并。(2)一个1:n联系可以转换为一个独立的关系模式,也可以与n端所对应的关系模式合并。792021精选ppt(3)一个m:n联系转换为一个关系模式。转换的方法为:与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,新关系的码为两个相连实体码的组合。(4)三个或三个以上实体间的多元联系转换为一个关系模式。802021精选ppt3.关系合并规则为了减少系统中的关系个数,如果两个关系模式具有相同的主码,可以考虑将它们合并为一个关系模式。合并的方法是将其中一个关系模式的全部属性加入到另一个关系模式中,然后去掉其中的同义属性,并适当调整属性的次序。返回本节812021精选ppt逻辑结构设计综合实例下面仍以图书管理系统的基本E-R模型(图8-17)为例,说明基本E-R模型转换成初始关系模型的规则:(1)将图8-17中的实体转换成关系模式。(2)将图8-17中的1:n联系“属于”转换为关系模型。(3)将图8-17中的m:n联系“借还”转换为关系模型。(4)将具有相同码的关系合并。822021精选ppt数据性质关系名属性说明实体读者借书证号,姓名,性别,部门,类别代码,办证日期,借书证状态类别代码为与“属于”联系合并后新增的属性实体读者类别类别代码,类别名称,可借阅数量,可借阅天数,超期罚款额

实体图书书号,书名,作者,价格,出版社,库存数量

联系借还借书证号,书号,借书日期,还书日期

表8-1图书管理系统的关系模型信息返回本节832021精选ppt将一般的关系模型转换为oracle下的关系模型下面就将图书管理系统中的关系设计成oracle下相应的表,如下所示。(1)READER(读者表)。字段代码字段名称字段类型长度小数是否为空CARDID卡号varchar220

NOTNULLNAME姓名varchar216

NOTNULLSEX性别varchar2

2

NULLDEPT部门varchar230

NULL842021精选ppt字段代码字段名称字段类型长度小数是否为空ClASSID类别代码number

NOTNULLBZDATE办卡日期datetime

NULLCARDSTATE卡状态varchar2

2

NULL852021精选ppt(2)DZCLASS(读者类别表)。字段代码字段名称字段类型长度小数是否为空CLASSID类别代码int

NOTNULLCLASSNAME类别名称varchar216

NOTNULLPERMITDAY可借阅天数int

NULLPERMITQTY可借阅数量int

NULLPENALTY超期罚款额money

NULL862021精选ppt(3)BOOK(图书表)。字段代码字段名称字段类型长度小数是否为空BOOKID书号varchar220

NOTNULLBOOKNAME书名varchar220

NOTNULLEDITER作者varchar28

NULLPRICE价格money

NULLPUBLISHER出版社varchar220

NULLQTY库存数量int

NOTNULL872021精选ppt(4)BORROW(借还表)。字段代码字段名称字段类型长度小数是否为空CARDID借书证号varchar220

NOTNULLBOOKID书号varchar220

NOTNULLBDATE借书日期datetime

NOTNULLSDATE还书日期datetime

NULL返回本节882021精选ppt数据模型的优化(1)确定各属性之间的数据依赖。(2)对各个关系模式之间的数据依赖进行极小化处理,消除冗余的联系。(3)判断每个关系的范式,根据实际需要确定最合适的范式。(4)根据需求分析阶段得到的处理要求,分析这些模式是否适用于用户的应用环境,从而确定是否要对某些模式进行分解或合并。(5)对关系模式进行必要的分解,以提高数据的操作效率和存储空

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论