通过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 数据的介绍,望你能有所收获  。