Hibernate存储Clob的方式总结@Toni.pdfVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Hibernate存储Clob的方式总结@Toni

题目 Hibernate存储 Clob的方式总结 作者 Toni 备注 1.背景 数据库的大字段操作向来属于数据库操作中最麻烦的部分。在 Java 开发中, 无论是使用 JDBC 还是使用 Hibernate 这样的持久化映射工具。大字段操作的 代码都是又丑又长,散发出一种“坏味道”。 在网上搜索一下,能找到的代码大多非常复杂。其实,随着厂商的不断努力, 对于大字段的操作已经越来越容易了。比如 SQL Server 2005 中推出了新的大 字段类型,可以向操作 varchar2 等普通字段类型一样操作大字段。Oracle 也 推出了支持以String的方式处理Clob的新驱动程序(仅限10g及其以上版本)。 Java 开发中,持久化的工具首选 Hibernate。但是网上和参考书上的 Hibernate 操作大字段例子,要么是古老的 1.x 版本的,在新版本下已经无法 执行了,要么是自己写自定义类型,晕呼呼的没几个人看得明白。其实,配合各 家厂商推出的新特性,Hibernate 可以很容易的操作 Clob 字段了。 最近需要将一个长度超过 4000 的字符串存储至数据库,而 varchar2 允许 的字符串最大长度为 4000 个,怎么办呢,经过实验,可以使用如下方法进行 Clob 的操作。该方法使用 String 直接映射 Clob。不用去转换 Clob 开流,也 不用写 Hibernate 自定义类型,更不用必须和 Spring 耦合,使用 Spring 的专 用 Hibernate 支持。 2.简单存储方式 2.1 建立如下表(表名:ITEMS_SAVECLOB),包含 Clob 字段 2.2 建立 JAVA 工程,并搭建 Hibernate 环境,这里只介绍工程结构,及所依 赖 JAR 包,搭建过程非常简单,就不再赘述了。工程结构如下: 所依赖 JAR 包如下: 2.2 与数据库表相对应的 JavaBean,名称:ItemsSaveclob.java,如下:(在 ItemsSaveclob.java 类中,属性 content 在数据库是 Clob 字段,但在这里 使用 String 类型进行处理) ItemsSaveclob.hbm.xml 映射文件配置如下: 注:在映射文件中,content 同样使用 java.lang.String 类型进行映射 2.3 在 Hibernate 配置文件中加入红框中配置,特别注意配置文件中 hibernate.connection.SetBigStringTryClob部分,这是 Oracle 必须添加 的属性,其它配置没有什么特别的。 2.4 存取测试 到这里,就完成了配置,现在编写如下测试类进行存取测试 测试结果: 由于 content 字段为 Clob 类型,故需要点击进行查看,其中内容为: 如果你将 4003 个字符存入 title 会报 SQL 异常的错误,title 的类型为 varchar2(4000),报错如下: 3.传统存储方式 3.1 建立如下表(表名:ITEMS_CLOB),同样包含 Clob 字段 在这里,我们使用原来工程,其实也可以使用原来的表 ITEMS_SAVECLOB 进 行实验,只是为了区别两个实验的不同 3.2 与数据库表相对应的 JavaBean,名称:ItemsClob.java,如下:(在 ItemsClob.java 类中,属性 content 在数据库是 Clob 字段,在这里使用 Clob 类型进行处理),如下: ItemsClob.hbm.xml 映射文件配置如下: 注:在映射文件中,content 同样使用 java.sql.Clob 类型进行映射 3.3 在 Hibernate 配置中不再需要加入 hibernate.connection.SetBigStringTryClob配置,使用正常普通配置即可 3.4 存取测试 完成了配置,现在编写如下测试类进行存取测试 测试结果: 4.Hibernate 框架中 getCurrentSession()与 openSession()的区别 (1)如果使用的是 getCurrentSession 来创建 session 的话,在 commit 后, session 就自动被关闭了,也就是不用再 session.close()了。但是如果使用的 是 openSession 方法创建的 session 的话,那么必须显示的关闭 session,也 就是调用 session.close()方法。这样 commit 后,session 并没有关

文档评论(0)

l215322 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档