第8章Web数据库技术数据库原理及应用本章引入在Internet的热潮席卷之下,原本在单机或局域网中使用的数据库逐步移植至Internet中,Web技术与数据库管理系统(DBMS)相互融合成为必然趋势,数据库厂家和Web公司纷纷推出各自的产品和中间件支持Web技术和DBMS的融合,将两者取长补短,发挥各自的优势,使用户可以在Web浏览器上方便地检索数据库的内容。Web数据库得以迅猛发展起来。本章教学内容Web数据库的产生与发展1Web数据库系统的体系结构2Web数据库访问技术3数据库访问接口4动态页面开发技术58.1Web数据库的产生与发展第8章Web数据库技术教学内容万维网一、万维网(WorldWideWeb,简称为Web)是欧洲粒子物理实验室的TimBerners-Lee于1989年3月提出的。1、什么是万维网并非某种特殊的计算机网络,而是一个大规模的、联机式的信息储藏所,是一个基于超文本方式的信息检索服务工具。万维网上不同地点的许多信息资源有机地组织在一起,连结成一个信息网,通过链接的方法(超链接)能够非常方便地从Internet上的一个站点访问另一个站点,从而主动地按需获取丰富的信息。2、万维网最大的特点万维网最大的特点是拥有非常友善的图形界面,非常简单的操作方法,以及图、文、声、像并茂的显示方式。3、万维网的组成万维网由分布在全球各地的Web节点组成;Web节点由Web服务器维护和管理的多个Web页面组成;页面是可以包含文本、表格、图像、动画、声音、3D世界,以及其它任何信息的超媒体文档,每个Web节点都有进入该节点的起始页面,称为该节点的“主页”;页面与页面之间通过超链接相连,可以从一个页面通过超链接进入同一节点或其它节点上的另一页面。4、万维网的标准万维网的成功在于其制定了一套简单易用的统一标准,包括:信息资源的统一资源定位符(UniformResourceLocator,简写为URL)超文本标记语言(HyperTextMarkupLanguage,简写为HTML)超文本传输协议(HyperTextTransferProtocol,简写为HTTP)万维网使用统一资源定位符URL来标识网上的各种资源,并使每一个资源在整个Internet的范围内具有唯一的标识符URL。万维网使用超文本标记语言HTML作为制作万维网页面的标准语言,消除了不同计算机之间信息交流的障碍,使任何一台计算机都能显示出任何一个万维网服务器上的页面。万维网以客户机/服务器方式工作。客户机与服务器之间通过超文本传输协议HTTP通信。HTTP协议定义了浏览器怎样向Web服务器请求万维网文档,以及服务器怎样把文档传送给浏览器,它是万维网上能够可靠地交换文件的重要基础。二、Web数据库在传统的Web服务中,文本和其他多媒体信息都是以文件的形式来进行存储和管理的,随着Web应用领域的不断扩展、信息量的不断增加,静态的Web页面越来越不能满足人们对Web信息服务的动态性、实时性和交互性的要求。为了进行网络上数据的高效存取,实现交互式动态Web页面,就必须以大量数据资源为基础,因此必然要在Web中引入数据库。1、Web数据库的概念从Web的角度来看待数据库,Web数据库是指将数据库技术与Web技术融合,使数据库成为Web的重要组成部分的数据库。就是用户利用浏览器作为输入界面,输入必要的数据,浏览器将这些数据传送至网站,网站再对输入数据实施处理,并将其执行的结果返回给浏览器,通过浏览器将最终执行结果提交给用户。可以简单地认为:Web数据库就是Internet+数据库。1、Web数据库的概念Web数据库不仅集合了Web技术和数据库技术的优点,而且使二者都发生了质的变化:Web网页从静态网页发展成了由数据库驱动的动态网页,而数据库实现了开发环境和应用环境的分离,用户端可以用统一的浏览器实现跨平台和多媒体服务。2、通过访问数据库的优点(1)借用现成的浏览器软件,无需开发数据库前端。(2)标准统一,开发过程简单。(3)交叉平台支持。三、Web数据库的发展阶段Web数据库发展到现在,经历了三个发展阶段。1、第一阶段第一阶段:Web数据库提供静态访问和静态内容应用。早期的Web数据库提供静态文档的管理和访问:程序员根据数据库内容用HTML编写Web页面,用户对数据库的访问实际是对该静态HTML文档的访问。第一阶段Web数据库是在还没有出现Web数据库访问技术的时候产生的,基本只是Web技术。缺点:不能实时访问,数据库维护工作量很大。2、第二阶段第二阶段:Web数据库提供静态访问和动态内容应用,实现基于数据库的动态文档的管理和访问。在第二阶段的Web数据库中,使用通用Web网关接口编程,使数据库能与Web服务器直接连接,实时动态地将数据库的信息反映在页面上。用户访问的是静态的HTML文档,但文档内容是随着数据库而改变的动态内容。缺点:不能保持数据库连接状态,存在性能瓶颈,缺少扩展性和保密性3、第三阶段第三阶段:Web数据库除了提供第二代Web数据库的功能外,还能提供基于Web的联机事务处理能力,在Web的客户端与服务器端实现了动态和个性化的交流和互动。第三阶段的Web数据库使所有对数据库的操作(增加、删除、修改)、信息的查询和管理都通过统一标准的Internet浏览器界面来进行,更加适应Internet技术的发展和网络互连的需要。8.2Web数据库系统的体系结构第8章Web数据库技术教学内容数据库的客户机/服务器体系结构1基于浏览器/服务器模式的Web数据库2引入数据库系统的体系结构是指在计算机系统环境下数据库管理系统及其数据库应用系统的体系结构。数据库系统的体系结构与数据库系统的应用环境是密切相关的,随着计算机技术的发展以及数据库系统应用环境的演变,数据库系统的体系结构也在不断地演变。随着计算模式经历了集中式模式、C/S模式和B/S模式三个阶段的发展,数据库系统也随之出现了相应的体系结构。一、数据库的客户机/服务器体系结构1、客户机/服务器体系结构客户机/服务器(C/S)结构是以计算机网络环境为基础,将计算任务有机地分配给多台计算机的计算模式。客户机/服务器结构由三部分组成:客户机、服务器、客户机和服务器之间的连接支持。1、客户机/服务器体系结构1)客户机客户机一般是一台面向最终用户,运行前端应用程序且提供外围开发工具,并通过网络获得服务器服务的微型计算机。2)服务器服务器一般是具有高档硬件资源和高性能软件资源的多用户计算机系统。3)连接支持是一种实现客户机和服务器之间连接和通信的标准网络接口和标准软件接口。2、客户机/服务器结构数据库系统客户机/服务器结构的数据库系统是把DBMS功能和应用分开,使网络中某个(些)结点上的计算机专门用于执行DBMS的功能,称为数据库服务器。其它结点上的计算机安装DBMS的外围开发工具,支持用户的应用,称为客户机(或应用服务器)。二者相结合、协同工作。其基本思想是服务器资源共享,但功能是分布的。它把单机环境下的DBMS功能在网络(包括多台计算机)环境下进行合理的分布,在客户机和服务器之间作适当的配置。2、客户机/服务器结构数据库系统客户机1应用程序1客户机2应用程序2客户机n应用程序n…网络中间软件DBMSDB网络数据库服务器在服务器一端完成DBMS的核心功能,包括接收来自客户端的数据库请求;处理数据库请求;进行安全性确认和完整性检查等。在客户端放置应用开发工具,完成管理用户界面;接受用户数据;处理应用任务;生成数据库请求并向服务器发出数据库请求;从服务器接受结果并格式化结果等。网络中间软件则遵循一定标准,负责透明地连接客户机与服务器,提供了访问数据库的统一界面。二、基于浏览器/服务器模式的Web数据库浏览器/服务器(B/S)计算模式是随着Internet技术的迅猛发展而发展起来的一种新型的网络计算模式。B/S结构是Internet技术和数据库技术相结合的过程中形成的数据库系统体系结构。B/S结构代表了当前数据库应用软件技术发展的趋势,是目前人们开发Web数据库系统普遍采用的数据库系统结构。B/S结构是C/S结构的继承和发展,从本质上讲,B/S计算模式和C/S计算模式都是一种请求/应答方式,但C/S计算模式需要在客户机上装载大量的应用软件,负担较重;而B/S计算模式是一种基于Hyperlink(超链接)、HTML(超文本标记语言)、Java的三层C/S结构,客户机上只需安装单一的浏览器软件,负担很轻,因此是一种全新的体系结构。1、B/S结构概述B/S结构将数据处理过程分为表示层、功能层和数据层三部分,分别由Web浏览器、具有应用程序扩展功能的Web服务器和数据库服务器实现。浏览器浏览器浏览器…网络数据库服务器DBWeb服务器DBSQL请求回送结果表示层功能层数据层2、三层B/S结构的数据库系统表示层位于客户端。表示层的任务是由Web浏览器向网络上的某一Web服务器提出服务请求,Web服务器用超文本传输协议和超文本标记语言来描述和组织信息,把所需的主页传送给客户端,客户机接受传来的主页文件,并把它显示在Web浏览器上。功能层位于第二层。功能层的任务是接受用户的请求,与数据库进行连接,通过SQL等方式向数据库服务器提出数据处理申请,并将数据库服务器的数据处理结果传送回客户端。数据层位于第三层。数据层的任务是接受Web服务器对数据库操纵的请求,实现对数据库查询、修改、更新等功能,把运行结果提交给Web服务器。在B/S结构中,可将数据库服务器端进一步分解成一个Web服务器和一个或多个数据库服务器。3、多层B/S结构的数据库系统浏览器1浏览器2浏览器n数据库服务器DB…网络Web服务器DB应用服务器(Web)应用服务器(Web)…(1)规范和统一了客户端程序的标准——浏览器模式,减轻了客户端的压力,解决了C/S结构中客户端程序的异构性和跨平台性。(2)将用户交互、应用业务处理和数据管理三者相互彻底分离,从而方便进行严格的安全管理、提高程序的可维护性,使其各自完成其擅长和应该完成的任务。(3)在表示层对数据的输入进行分析检查,可尽早消除错误输入,减少网上传输的数据量,加快响应速度。4、B/S结构数据库系统的优点(4)软件维护开销能够大大降低。(5)充分发挥了DBMS高效的数据存储和数据管理能力,把传统的数据库访问、存取和维护等技术应用于Internet的Web之上,实现了更大程度和更大范围的数据库资源共享。4、B/S结构数据库系统的优点8.3Web数据库访问技术第8章Web数据库技术教学内容对Web数据库访问技术的要求1Web数据库访问技术的种类2Web数据库设计的一般过程3引入Web数据库系统的主要目的是要实现Web与数据库的连接以产生基于数据库的动态页面,这要通过Web访问数据库来实现,相关的技术我们称之为Web数据库访问技术(也称为动态页面技术)。一、对Web数据库访问技术的要求(1)高效性(2)安全性(3)客户端的简洁性(4)开放性(异构性)(5)可扩展性二、Web数据库访问技术的种类1、基于中间件的Web数据库系统2、基于客户端的Web数据库系统3、上述两种方法的组合1、基于中间件的Web数据库系统是在Web服务器端提供中间件来连接Web服务器和数据库服务器,常用的中间件技术有通用网关接口(CGI)、应用程序编程接口(WebAPI)、ODBC、JDBC、ADO、ADO.NET等。Web浏览器Web服务器中间件(CGI、API、ODBC、JDBC、ADO、ADO.NET等)数据库这些技术的特点是采用Web服务器作为通信中介,由Web服务器启动应用程序,并由应用程序完成数据库的访问,结果信息再经Web服务器返回客户端浏览器。2、基于客户端的Web数据库系统是把应用程序下载到客户端运行,在客户端直接访问数据库服务器,例如:JavaApplet等。Web浏览器Web服务器客户端应用(JavaApplet)