通过Hibernate 来映射 DB2 pureXML 数据的应用 |
本文标签:DB2 pureXML 本文主要介绍的是正确使用 Hibernate 来简化基于DB2 pureXML 的相关应用程序的实际开发我们主要是通过N个例子来映射 DB2 pureXML 的数据,减少开发难度 。以下就是文章的主要内容的详细描述,望大家在浏览之后会对其有更深的了解 。 前提 读者需要对 Hibernate 框架和 DB2 pureXML 相关技术,如 SQL/XML,XQuery 等有一定的了解 。本文所述基于 DB2 V9.5 和 Hibernate 3.3.1GA 。由于 DB2 V9.7 的 Sample 数据库中示例 XML 表中不再包含命名空间,如果读者使用 DB2 V9.7,读者需要在示例代码中去掉对命名空间的声明 。 Hibernate 简介 如今的企业级应用程序的开发基本都是以面向对象的方式进行的,Java 社区丰富的资源为开发过程提供了产品质量和开发效率的双重保障 。然而,在数据库层面,由于各种原因,比如使用习惯,性能考虑等因素,却依旧沿袭了“实体 - 关系”的数据模型设计,将立体化的对象切割成为各个平面的表结构,然后再在这些表之间建立起来关联 。另一方面来讲,数据库本身的发展也遇到了瓶颈,暂无很好的办法以直接的方式管理对象(本文指 Java 类的实例),提供基于对象的 CRUD( 增删改查 ) 等操作,以及事务控制等 。 基于以上考虑,开源的 Hibernate 作为一个关系型数据库的对象映射框架,已经成为了企业级应用程序开发人员的首选 。开发人员常常利用 Hibernate 作为粘合剂,把 Java 对象和关系型数据库粘合起来,免去手工映射的繁琐工作 。 DB2 pureXML 的用武之地 Java 和 XML 可谓是天生的盟友 。两者都可以用来描述复杂的对象,而且两者之间的转换也易如反掌 。有许许多多的开源项目可以支持 Java 对象到 XML 的序列化 (serialization) 和 XML 文档到 Java 对象的反序列化 (de-serialization) 。 Java 利用 SAX 和 DOM 方式解析 XML 文档,并进行相应的操作,也是得心应手 。 如果给 Java 设计人员两个选择,其一是拆分 Java 对象为若干个复杂的表,这些表间又有千丝万缕的联系,其二是直接将 Java 对象序列化成 XML,然后存入数据库,同时保证插入查询等数据库操作的性能;我想很少有人可以拒绝第二个选择 。 DB2 pureXML 在这样的背景下可以发挥其独特的价值 。无需将 XML 文档拆分成关系表,可直接插入到数据库中;查询时,既可以把整个文档从数据库中取出来,也可以只摘取 XML 文档的某若干个节点元素,还可以将某一个或多个元素作为查询条件 。数据更新时,既可以将整个 XML 文档更新,也可以只更新文档的若干元素 。这些操作都是基于业界标准的 XQuery 和 SQL/XML 。关于 DB2 pureXML 的数据操作接口和方式,读者可以参考相应文章,这里不再赘述 。 这些特性无疑给了程序设计人员很大的想象空间和设计灵活性 。 Hibernate 和 DB2 pureXML 如何共存 Hibernate 作为一个 ORM(Object-Relational Mapping) 工具,首先考虑的是对象(Object)和关系表(Relational)之间的映射关系 。而 DB2 pureXML 所采用的 SQL/XML 和 XQuery 接口并没有在 Hibernate 中得到直接的支持 。咋看起来,似乎为了使用 DB2 pureXML,只能 放弃 Hibernate 框架,改用 JDBC 来实现数据访问接口 。 笔者经过一些探索,发现事实并非如此 。在 Hibernate 3.3.1GA 版本中,已经可以对 DB2 pureXML 的绝大多数操作提供支持 。只不过这些支持方式尚不为人熟悉罢了 。本文的剩余部分将分门别类的就如何在 Hibernate 框架之上开发 DB2 pureXML 的应用程序详细介绍 。 在阅读以下内容的同时,读者可以参考示例代码进行尝试 。在开始之前,建议用户创建包含 XML 示例表的 sample 数据库 。在 db2cmd 下运行 db2sampl – xml 即可 。 XML 示例表将创建在当前用户 schema 下 。 各种查询和对象映射方式 总体来讲,在 Java 语言中对 XML 文档的对象映射通常采用以下几种方式 : 映射成为 DOM 对象 ; 摘取 XML 文档中的部分元素 , 映射成为普通 Java 类 ;
对复杂多层次的 XML 文档 , 映射成为若干个互相引用的 Java 类 ;
将 XML 文档映射成为动态类的实例 。
而在 Hibernate 里面,可以有如下更丰富的选择 。当然,这些选择也只是对以上方式的扩展而已 。
整体获取 XML 文档 Hibernate 支持将 XML 文档直接映射为 java.lang.String 类型 。因此,如果希望获取整个 XML 文档,可以采用这种方式将 XML 文档返回为 Java 的 String 对象,然后在 Java 程序中使用 JDOM 等工具对该对象做进一步处理 。这种处理方式和对 CLOB 数据类型的处理方式类似 。 另外,Hibernate 允许用户自定义数据类型,由该数据类型和数据库中 XML 列直接交互 。读者可以参考https://www.hibernate.org/466.html,该篇文章介绍了如何编写自定义用户类型来将 DB2 中的 XML 列映射成为 DOM 对象 。 原生 SQL 查询 Hibernate 常用的查询语言是 HQL,但是也支持数据库原生 SQL 。用户可以直接编写原生 SQL 来支持具有数据库独有特性的 SQL 。如清单 1 所示,用户编写 SQL/XML,读取 /customerinfo/name 节点和 /customerinfo 下的 Cid 属性 。 以上的相关内容就是对使用 Hibernate 映射 DB2 pureXML 数据的介绍,望你能有所收获 。 |