通过Hibernate 来映射 DB2 pureXML 数据的应用

数据库
此文章主要介绍的是通过Hibernate 来映射 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 数据的介绍,望你能有所收获。

【编辑推荐】

  1. 使用DB2临时表时有哪些问题是需要注意的?
  2. 对DB2 9.7武器的功能的描述
  3. IBM DB2连接集中器的基本操作原理
  4. DB2 V9.5 新特性有哪些好处?
  5. DB2 batch update注意事项的描述

 

 

责任编辑:佚名 来源: 万国数据
相关推荐

2009-09-22 12:25:04

ibmdwDB2

2009-04-17 10:07:42

2011-11-30 21:46:24

ibmdwDB2 pureXML

2010-08-20 12:49:49

DB2 pureXML

2009-01-18 16:33:09

pureXMLDB2 pureXMLXML

2009-03-10 10:31:26

DB2XMLpureXML

2009-11-23 19:57:01

ibmdwDB2

2010-07-28 14:07:51

DB2数据库

2009-03-03 12:58:14

pureXML大小写DB2

2010-08-19 10:53:27

DB2dart 工具

2011-03-15 14:13:56

JDBCDB2数据库

2010-09-01 14:07:33

DB2映射

2010-08-11 09:14:33

DB2数据类型

2011-05-13 09:49:55

DB2数据移动

2010-08-26 11:05:39

DB2数据移动

2010-08-10 15:30:21

2010-08-10 17:17:59

2011-03-11 16:02:03

DB2数据库安装

2010-08-04 08:52:35

2009-07-06 17:34:26

远程复制DB2
点赞
收藏

51CTO技术栈公众号