面向对象数据库Xindice的应用系统毕业设计说明书.doc
本科毕业设计说明书(论文)题目: 面向对象数据库Xindice的应用系统 毕业设计(论文)原创性声明和使用授权说明原创性声明本人郑重承诺:所呈交的毕业设计(论文),是我个人在指导教师的指导下进行的研究工作及取得的成果。尽我所知,除文中特别加以标注和致谢的地方外,不包含其他人或组织已经发表或公布过的研究成果,也不包含我为获得 及其它教育机构的学位或学历而使用过的材料。对本研究提供过帮助和做出过贡献的个人或集体,均已在文中作了明确的说明并表示了谢意。作 者 签 名: 日 期: 指导教师签名: 日期: 使用授权说明本人完全了解 大学关于收集、保存、使用毕业设计(论文)的规定,即:按照学校要求提交毕业设计(论文)的印刷本和电子版本;学校有权保存毕业设计(论文)的印刷本和电子版,并提供目录检索与阅览服务;学校可以采用影印、缩印、数字化或其它复制手段保存论文;在不以赢利为目的前提下,学校可以公布论文的部分或全部内容。作者签名: 日 期: 面向对象数据库Xindice的应用系统摘 要XML文档是以文本形式来描述的,它的自描述性使之非常适用于不同应用间的数据交换。为了交换XML的业务数据,就必须把XML文档存储在数据库中,并且把它和应用程序结合起来。XML一开始就建构在Unicode之上,具有世界通用性,本地化的XML数据处理具有广阔的发展前景。论文中提到的演示系统是指校园信息管理系统。它是基于Browser/Server(浏览器/服务器)架构的。系统采用的数据库是用于存储XML文档的典型开放源码数据库Xindice;采用了XML数据库查询技术Xpath,XML数据库更新技术Xupdate,XML文档转换技术XLST,以及JSP、SERVLET技术等;以TOMCAT作为web服务器。系统实现了校园信息管理中的常见功能,系统管理员可以对学生信息、教师信息、班级信息进行管理,也可以进行课程设置。系统使用者学生可以查看个人信息,可以进入选课系统进行选课,也可以修改个人账户。系统使用者教师可以查看个人信息,可以修改个人账户,也可以申请开设课程。演示系统实现了校园信息管理中的简单操作,系统利用面向对象数据库Xindice以集合的方式来管理XML文档,而校园信息就存储于XML文档中;系统将我们常见的表之间的关系映射到XML的描述文档结构中,实现了面向对象数据库中的数据的级联删除操作。随着XML技术的发展,XML同数据库的结合将会实现更强大的功能,本应用系统具有一定的参考价值。关键字:xindice, xml, xpath, xupdate, xlstAPPLICATION SYSTEM BASED ON OBJECT-ORIENTED DATABASE XINDICEABSTRACTXML is a file format which is described in text format. It is self-descriptive and very suitable for data exchange among different applications. To exchange XML business data, XML data should be stored in database, and they are often combined with applications. XML document is based on Unicode, which is world-universal. XML data processing on relationship is a promising approach.The demo system for campus information management is based on Browser/Server (B/S) structure. The database of the campus information system is a typical open source database that is used to store XML document; XML database query technology - Xpath, XML database update technology - Xupdate, XML documents conversion technology XLST, JSP and SERVLET technology are implemented in the management system; and the system is hosted on TOMCAT as the application server.The system has realized common features for the management of campus information. The system administrator can manage student information, teacher information and class information, course information as well. Student, one type of system users, is able to view personal information and enter into the elective system of course selection to do some operation such as select course operation. The student can also modify individual account. Teacher, another type of system users, can retrieve personal information and modify individual accounts and can also apply for a new course. The manage system has also realized some simple operation in the campus information management. The Xindice database is applied in the management system to store and manage the xml document in the way of collection and campus information is stored in the xml document. The system realizes mapping of the relations between tables and xml document structure and realize the operation of cascade of data deletion in the object-oriented database. With the development of XML technology, the combination between XML and database will be achieved with more powerful features, this application has some reference value.Key Words: xindice, xml, xpath, xupdate, xlst目 录摘 要1ABSTRACT3第一章绪论11.1项目背景11.2研究现状21.3研究开发的目标和基本内容31.3.1研究开发的目标31.3.2研究开发的基本内容41.4论文概要说明5第二章应用技术概论72.1Xindice数据库72.1.1Xindice数据库简介72.1.2Xindice系统结构82.1.3Xindice存储实现方案82.2Apache Tomcat服务器92.3XML查询技术Xpath92.3.1Xpath介绍92.3.2Xindice数据库对Xpath的支持102.4XML更新技术Xupdate122.5XML转换技术XSLT15第三章演示系统介绍173.1系统整体架构173.2系统数据存储193.2.1数据库表设计193.2.2数据库表到XML文档结构的映射213.3系统数据流程26第四章技术应用324.1Xindice数据库的搭建324.1.1搭建前的准备工作324.1.2安装Xindice数据库334.1.3测试Xindice数据库334.2Xpath的应用344.2.1连接Xindice数据库344.2.2处理Xpath的结果集354.3Xupdate的应用374.3.1Xindice提供的Xupdate接口374.3.2利用Xupdate增加数据374.3.3利用Xupdate删除数据384.4XLST的应用404.4.1动态生成XML404.4.2编写XSL样式表414.4.3XML中调用XSLT424.5数据库查询分析43第五章总结45参考文献47致谢49附录50附录1 毕业设计文献综述50附录2 毕业设计开题报告50附录3 毕业设计外文翻译(中文译文与外文原文)50第一章 绪论1.1 项目背景面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的,两套理论存在显著的区别。为了解决这个不匹配的现象,对象关系映射技术应运而生。对象关系映射(Object Relational Mapping,简称ORM1)是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将Java程序中的对象自动持久化到关系数据库中。本质上就是将数据从一种形式转换到另外一种形,这也同时暗示着额外的执行开销。目前流行的ORM产品有Apache OJB2、Hibernate等。随着现代社会的发展,许多新的复杂的结构开始涌现如生物高分子等,关系数据库在处理这类复杂结构时已显得非常吃力,XML就非常适合处理这类复杂的结构。因为XML的最大优点是它对数据描述和数据传送能力,具备很强的开放性3。Apache Xindice4是一种本地XML数据库,可以在该数据库中保存、查询和修改XML文档。与关系数据库相比,本地数据库的优点是无须将XML映射到SQL。该数据库使用Xpath查询Xindice数据库,使用XML:DB Xupdate来更新数据库。Xindice实现了Java XML:DB API,用于在Xindice数据库中添加、查询和更新XML文档。Xindice数据库中的XML文档保存在集合中;一个集合可以包含一个或多个XML文档。Xindice还提供一种命令行工具,该工具具有与XML:DB API相同的功能。利用XML文档存储结构化的数据,在Xindice中以集合的方式存储XML文档,可以实现一个小型的应用系统。演示系统中没有用到常见的关系数据库如:SQL SERVER、Oracle,而是用到了XML数据库Xindice,它直接存储XML文档,不存在映射的问题。由于使用了XML,又增强了数据表现力。1.2 研究现状目前XML数据库产品主要有DB2 9,BaseX,Ozone,MyXmldb,Exist,Xindice。IBM DB2 9作为第一个混合型的数据库服务器,它可以处理关系型数据同时也可以处理XML数据。特别是对 XML 数据的支持,可以说是数据库发展史上的一个重要里程碑;DB2 9混合型数据库引擎可为在数据库中同时存储关系数据和 XML数据提供灵活性和高性能,因为数据库管理系统在每一个层面(从客户端到引擎,再到磁盘)都能很好的了解和支持这两种数据模式。XML数据继承了DB2为关系数据提供的相同的备份与恢复、优化、可伸缩性和高可用性。DB2 9对XML独特支持,保证了XML数据与生俱来的层次结构和灵活性模式,大大增强了企业适应信息变化的能力,提高了企业随需应变的水平。关系型与层次型数据的混合处理能力使企业信息的无缝集成成为可能。通过一个访问请求就可以同时支持关系型数据以及XML数据,从而大大提高生产效率。BaseX是一个XML数据库,用来存储紧缩的XML数据。它提供了高效的Xpath和XQuery的实现,还包括一个前端操作界面。BaseX 6.0实现了完整的XQuery Update规范、100%达到W3C的测试要求。引入一个增强的客户端服务器的体系架构,基于ACID安全事务、用户和密码管理、事务日志等。扩展了XQuery的全文特性、支持TF/IDF排名、停止词列表和模糊查询。使用固定内存来提升了索引创建过程,改进了索引的结构和迭代查询处理。Ozone是一个面向对象的数据库管理系统,完全用Java实现Ozone项目的目的是让开发者可以构建一个纯面向对象、纯Java的数据库应用程序。Ozone可以用来存储XML文档,可以用任一个XML工具来访问这些数据。MyXmldb是一个在MySQL上实现的XML数据库。它以BLOB形式存储文档,可以多达256M大小的文档。它支持Xpath和XQuery,并提供了XML的Java实现XML:DB API,具有图形用户界面。Exist是一个开源的native XML数据库。它有依据索引的XQuery处理程序,可以自动进行索引,扩展的全文本搜索,Xupdate支持并且它与现存的XML开发工具可以紧密的结合在一起。Exist-db支持很多网络技术标准,使它成为开发WEB应用程序的优秀平台。它支持XQuery 1.0、Xpath 2.0、XSLT 1.0(using Apache Xalan)和XSLT 2.0。Xindice数据库起源于DBXML数据库。DBXML数据库是第一个开放源码的native-XML数据库。该项目在1999年7月启动,由Tom Bradford发起,Kimbro Staken负责管理。在2001年并入Apache开放软件联盟并更名为Xindice,现今Xindice 数据库已是世界上最广泛使用的数据库之一5。现在Xindice官方发布的稳定版本为V1.1,V1.2是一个开发中的版本。Xindice是Native-XML数据库。文档分为以数据为中心的文档和以文档为中心的文档6。Native-XML数据库的观点认为在数据库中应当以XML原始的格式存取XML文档,数据库内部的数据模型是依据XML特性建立的7。Native-XML数据库是一种专门的保存、检索和处理文档的数据库,它支持文档的结构,因此能保留它们的数据层次结构和意义8。当前XML文档的基本存储方式9可分为3类:文件系统、存储管理器和数据库管理系统。第3种更有效的存储方式是使用数据库管理系统来管理XML数据。根据数据库管理系统的不同,这种存储方式又可以分为基于关系的XML数据库系统、面向对象的XML数据库系统和“原生(native)”的XML10。Xindice数据库既是面向对象数据库,又是原生XML数据库。当前XML主要应用领域体现在4个方面:企业间电子商务,知识管理,文档管理,实现企业的自动化处理11。XML具有如此广泛的应用,而Xindice又是用于存储和管理XML文档的面向对象数据库,Xindice必将有良好的发展前景。集成XQuery功能的Xindice数据库12在近几年也被设计出来,使用Xindice数据库来查询XML数据变得更加容易。1.3 研究开发的目标和基本内容1.3.1 研究开发的目标在当前互联网络和XML技术如此发达的基础上,本系统拟在研究类似应用系统的设计实现上,提出自己的设计实现。作为数据表示的一个开放标准,XML语言给Web应用乃至网络计算注入了新的活力13。网络发展的同时,XML技术也在发展。基于XML/Web服务的跨平台的分布式技术给电子商务的系统构建、系统部署以及数据集成等带来了许多新的思路和挑战14。用于处理XML的数据库技术也显得尤为重要。Xpath是一门在XML文档中查找信息的语言。Xpath可用来在XML文档中对元素和属性进行遍历。Xpath是W3C XSLT标准的主要元素,并且XQuery和XPointer同时被构建于Xpath表达之上15。因此,Xpath是很多高级XML应用的基础。XSLT指XSL转换(XSL Transformations),它使用Xpath在XML文档中进行导航。XSLT是XSL中最重要的部分。XSLT用于将一种XML文档转换为另外一种XML文档,或者可被浏览器识别的其他类型的文档,比如HTML和XHTML。通常,XSLT是通过把每个XML元素转换为(X)HTML元素来完成这项工作的。通过XSLT,可以向输出文件中添加或移除元素和属性,也可以重新排列元素,执行测试并决定隐藏或显示哪个元素,等等。描述转化过程的一种通常的说法是,XSLT把XML源树转换为XML结果树16。Native-XML数据库是一种专门的保存、检索和处理XML文档的数据库,它支持XML文档的结构。Xindice是一个Java公开源代码的Native-XML数据库17,它支持XML文档结构,能够保存XML数据的层次结构和意义。本应用系统的研究目标定位于利用XML一些常用技术和Xindice数据库来实现一个小型的演示系统;将存储系统信息的XML文档存于Xindice数据库中;应用XML中的一些关键技术如XLST、Xpath、Xupdate来对XML文档进行操作;将系统中对象之间的关系映射到XML文档结构中,即通过文档节点中的相关信息进行关联;利用XLST对同一个XML文档进行多种显示;对XML文档的查询结果进行排序显示;通过Xpath查询XML文档获得系统重要数据信息、验证重要节点的存在,通过Xupdate来更新XML文档节点,包括对节点的增加、修改和删除操作,利用相关信息节点的匹配来实现关系数据库下的数据级联删除操作。整个演示系统的使用就如使用关系数据库那样,能够很方便地对数据进行操作。此信息管理系统的开发,是为了探讨一种新的解决问题的方法,为将来的研究开发做铺垫。1.3.2 研究开发的基本内容 n Xindice数据库的搭建u 搭建前的准备工作u Xindice数据库的搭建步骤u 搭建完后的数据库测试n XML信息文档的创建和数据库的导入u 系统对象的提取及关系抽取u 将对象之间的关系映射到XML的描述结构中u 将XML文档导入Xindice数据库n 查看Xindice数据库中的XML文档数据u Xpath的应用u Xindice数据库中Xpath的调用接口u Xpath查询语句的研究u Xpath查询结果的应用n Xupdate的应用u Xindice数据库中Xupdate的调用接口u Xupdate的应用分类u 利用Xupdate更新Xindice数据库中的XML文档数据n XLST的应用u XLST的转换过程u 利用XLST动态生成HTML1.4 论文概要说明第一章 绪论。主要介绍研究的背景、研究现状以及研究的目标和意义。对象关系映射(ORM)是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。使用ORM技术将带来额外的执行开销。关系数据库在处理复杂的高分子结构时已显得非常吃力。目前XML数据库产品主要有DB2 9,BaseX,ozone,MyXmldb,Exist,Xindice。信息管理系统的开发,是为了探讨一种新的解决问题的方法,为将来的发展做铺垫。研究开发的基本内容是Xindice数据库的使用和各种XML技术。第二章 应用技术概论。主要介绍了演示系统实现过程中用到的关键技术,如系统后台使用的数据库Xindice、XML查询技术Xpath、XML更新技术Xupdate和XML转换技术XLST。第三章 演示系统介绍。主要介绍了演示系统的整体架构、数据存储和数据流程。系统整体架构使用三个角色:管理员、学生、教师的用例图来展示。系统数据存储详细讲到了怎样用XML描述文档来存储关系数据库中的表。第四章 技术应用。详细介绍了演示系统中用到的关键技术,包括各种技术在演示系统中是如何使用的以及为了使用这种技术所做的准备工作。第五章 总结。对整个毕业设计的完成过程做了总结,包括系统中用到技术的介绍和系统存在的不足。 第二章 应用技术概论本章主要介绍了Xindice数据库、Apache Tomcat服务器和XML的处理技术,包括Xpath、Xupdate、XLST等XML处理技术的介绍。 2.1 Xindice数据库2.1.1 Xindice数据库简介Xindice数据库起源于DBXML数据库。DBXML数据库是第一个开放源码的Native-XML数据库。该项目在1999年7月启动,由Tom Bradford发起,Kimbro Staken负责管理。在2001年并入Apache开放软件联盟并更名为Xindice,现今Xindice数据库已是世界上最广泛使用的数据库之一。 Xindice数据库有以下特点:文档集合(Document Collections):文档被存储在可以被作为整体来查询的集合中。在数据库中可以创建只包含相同类型文档的集合,也可以创建一个集合来存储所有的文档。Xpath查询引擎:要查询文档集合,可以使用W3C定义的Xpath。这提供了相当灵活性的机制,通过定位和限制返回结果树来查询文档。XML索引:为了提高在大量文档上的查询性能,可以定义关于元素和属性值的索引。这可以极大的加速查询响应时间。XML:DB Xupdate实现:当存储XML到数据库时,或许需要能够在不检索整个文档的情况下改变数据。Xupdate是当需要做服务器端的数据更新时使用的机制。这是一种基于XML的语言,确定XML修改并允许这些修改像应用到单个文档一样应用于整个文档集合。Java XML:DB API实现:对于Java程序员Xindice提供了一个XML:DB API实现。这个API将给XML数据库应用带来可移植性,就像JDBC相对于关系数据库一样。大部分基于Xindice开发的应用将使用XML:DB API。命令行管理工具:为了帮助系统管理员,Xindice提供了一全套命令行驱动的管理工具。所有可以通过XML:DB API做的事情,也可以从命令行搞定。Xindice的主要特色为小型、实用。作为一个小型的XML文档管理数据库,其主要功能都已俱备,如XML文档的存取、索引、查询、修改、API等。但同非常完善的大型关系数据库相比,它还缺乏强有力的事务处理、并发操作、安全机制等功能5。2.1.2 Xindice系统结构Xindice服务器是设计用来存储XML文档集合的。集合可以按照层次结构来安排,与典型的UNIX或Windows文件系统相似。在Xindice中,数据存储基于一个亦可当文档集合使用的数据库实例。此数据库实例可以包含任意数目的子集合。在Xindice的缺省安装情况下,此数据库实例称为“db”,而所有的集合路径以/db开始。如果想要重命名这个数据库实例也是可以的,虽然没有必要这样做。Xindice数据库服务器可分为三层,分别为核心层、服务层和接口层,如图2.1所示。表2.1 Xindice数据库系统结构图接口层Command tool XML:DB API CORBA服务层DOM JAXP SAX SERVER核心层Store Indexer Object Query Filer Xupdate Xpath在表2.1中,核心层实现数据库的基本功能,包括数据类型、B+树索引、对象管理、Xpath查询、Xupdate数据修改等。服务层实现作为XML数据库服务器应该具有的一些功能,如:DOM、JAXP、SAX、服务器组件等。接口层实现外界与Xindice数据库进行数据交换和控制的接口,支持CORBA、XML:DB API、XML-RPC、HTTP、命令行管理等。系统还未实现图形用户界面下的数据库管理操作。2.1.3 Xindice存储实现方案Xindice数据库存储的基本概念是集合和资源。资源通常指XML文档,但也可以是一般文本或一段二进制代码。集合是包含资源的容器。这两个概念类似于关系数据库的表和记录,多个记录组成一张表,多个文档组成一个集合,多个表形成一个数据库,多个集合也构成一个数据库。但有两点不同,其一在于同一张表中的记录格式均一样,但同一集合中可以包含完全不同的文档;其二表与表是平等的,但集合可以是层次结构配置。集合的层次结构配置是指母集合下可有数个子集合,子集合下可有孙集合,这类似于文件系统。文档以压缩方式存入集合,集合以文件形式写入磁盘。对集合中的文档存取采用两种方式,一种是按名存取,另一种是按索引存取,即对元素和属性索引后,查询到该元素或属性后,将整个文档取出5。从外部可用两种方式对数据库进行操作,一种是命令行语言,另一种是XML:DB API,即应用程序接口。2.2 Apache Tomcat服务器Apache是世界上使用排名第一的Web服务器软件。它可以运行在几乎所有广泛使用的计算机平台上。因为它是自由软件,所以不断有人来为它开发新的功能、新的特性、修改原来的缺陷。Apache的特点是简单、速度快、性能稳定,并可做代理服务器来使用18。Tomcat服务器是一个免费的开放源代码的Web应用服务器,是Sun公司的JSP/Servlet的官方实现。它本身也可以作为独立万维网服务器使用,但它不以处理静态文件见长,所以一般都当作一个JSP/Servlet引擎与其他Web服务器软件配合使用19。因为Tomcat技术先进、性能稳定,而且免费,因而深受Java爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web应用服务器。2.3 XML查询技术Xpath2.3.1 Xpath介绍Xpath是一门在XML文档中查找信息的语言。Xpath可用来在XML文档中对元素和属性进行遍历。Xpath是W3C XSLT标准的主要元素,并且XQuery和XPointer同时被构建于Xpath表达之上。因此,Xpath是很多高级XML应用的基础。Xpath 1.0于1999年11月16日成为W3C推荐标准,Xpath 2.0是在2007年1月23日被确立为W3C推荐标准。但在当前的浏览器中Xpath 2.0是不被广泛支持的。XML在描述数据的定义和结构方面非常灵活、方便、高效,但它不能提供一种手段让用户定位到XML文档中结构化数据的指定位置。例如,一个存储了学生数据的XML文档,要想在其中找到某个学生的数据,如果没有其他的帮助,就要对每一个元素进行搜索,对于一个非常大的XML文档来说,这种搜索方法不仅效率低,而且极容易出错。XML路径语言(Xpath)提供了一种语法,它可以非常高效地定位XML文档中的各个部位,选择文档的各组成成分,如元素、属性、内容等。Xpath不像XML那样的结构化语言,它是基于字符串的表达式语言。主要用于其他的XML技术,例如XSL的一些元素的select/match/test等属性通常把Xpath表达式当作属性值。2.3.2 Xindice数据库对Xpath的支持Xindice支持Xpath查询语言。查询可以通过客户端应用程序进行,也可以通过命令行的方式。在许多应用程序中,Xpath只被应用在文档级别上而Xindice数据库中的Xpath查询应用在集合的级别上。这就意味着一次查询可以执行在多个文档上并且查询的结果集中也包含集合中多个文档的匹配节点。Xindice数据库也支持在常用的Xpath查询上创建索引来加速查询。Xpath查询文档的实例存储在Xindice数据库中的/db/addressbook集合下,其文档结构描述如下。图2.1 XML实例以下查询均基于图2.1的XML实例。Xpath查询可以分为以下几类:(1) 查询整个XML文档查询语句:Xindice xpath c /db/addressbook q “/personphone/type=cell”;执行结果:图2.2 Xpath查询一个文档的结果(2) 查询一个元素查询语句:Xindice xpath c /db/addressbook q “/person/phonetype=cell”;执行结果:图2.3 Xpath查询一个元素的结果(3) 查询一个文本节点查询语句:Xindice xpath c /db/addressbook q “/personfname=John/phone/text()” ;执行结果:图2.4 Xpath查询一个文本节点的结果(4) 查询一个字符串查询语句:Xindice xpath c /db/addressbook q “string (/personfname=John/phone)” ;执行结果:图2.5 Xpath查询一个字符串的结果(5) 查询一个数字查询语句:Xindice xpath c /db/addressbook q “count(/person/phone)” ;执行结果:图2.6 Xpath查询一个数字的结果上面的Xpath查询语句是用来统计XML文档中的电话号码个数。2.4 XML更新技术XupdateXupdate(XML更新语言XML Update Language)是一种指令语言,可以通过它来修改XML文档。Xupdate定义了用于修改XML文档数据的更新工具。该语言由XML:DB小组开发,该小组开发人员的兴趣在于开发XML数据库管理工具。Xindice实现了XML:DB Xupdate机制,以更新XML文档。使用Xindice命令Xupdate操作更新XML文档分为以下几类:Xupdate命令 描述Xupdate:insert-after 在选择的节点后添加节点Xupdate:update 更新选择节点Xupdate:remove 移除选择的节点a) 使用xindice命令添加元素 例如,我们将更新catalog.xml文件,以便将journal元素添加到XML文档中。在xupdate配置文件xupdate.xml中指定了要更新的元素和属性。要添加journal元素的配置文件xupdate.xml如下:<xupdate:modifications version="1.0"xmlns:xupdate="http:/www.xmldb.org/xupdate"><xupdate:insert-after select="/catalog/journal3"><xupdate:element name="journal"><xupdate:attribute name="date">Aug 2005</xupdate:attribute><article><title>iBatis DAO</title><author>Sunil Patil</author></article></xupdate:element></xupdate:insert-after></xupdate:modifications>使用以下命令更新XML文档:>xindice xupdate -cxmldb:xindice:/localhost:8088/db/catalog -n catalog.xml -f c:/xindice/xupdate.xmlxupdate操作指定要更新的XML文档。参数-f指定配置文件xupdate.xml。这将更新XML文档,并显示以下消息:1 documents updatedb) 使用Xindice命令删除和修改元素 再如,移除journal元素,并修改另一个journal元素中的title。下面以移除第一个journal元素,并修改第三个journal元素中的title为例。因为在更新第三个journal元素之前,移除了第一个journal元素,所以要更新的journal元素成为第二个journal元素。这时可以使用xupdate:remove移除某一元素和xupdate:update以更新一个元素。下面是用于移除和修改元素的配置文件xupdate.xml:<xupdate:modifications version="1.0"xmlns:xupdate="http:/www.xmldb.org/xupdate"><xupdate:remove select="/catalog/journal1"/><xupdate:update select="/catalog/journal2/article/title">Maven with Swing</xupdate:update></xupdate:modifications>使用以下命令更新XML文档:>xindice xupdate -cxmldb:xindice:/localhost:8088/db/catalog -n catalog.xml -f c:/xindice/xupdate.xml这将更新Xindice数据库中的XML文档。c) 使用XML:DB API添加元素 接下来,使用XML:DB API更新XML示例文档。作为一个示例,在第三个journal元素后面添加一个journal元素。下面以Xupdate字符串指定Xupdate命令。String xupdate ="<xupdate:modifications version="1.0"" +" xmlns:xupdate="http:/www.xmldb.org/xupdate">" +" <xupdate:insert-af