本文主要介绍的是正确使用 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 数据的介绍,望你能有所收获。
【编辑推荐】
网页名称:通过Hibernate 来映射 DB2 pureXML 数据的应用
文章来源:http://www.shufengxianlan.com/qtweb/news42/484442.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联