- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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 并没有关
您可能关注的文档
- GMAT语法介词与反身代词的搭配(一)-智课教育.pdf
- GMAT语法:超详细讲解代词指代.pdf
- GMAT管卫东Verbal-第07套-智课网.pdf
- GMAT语法逻辑类错误“有迹可循”(二).pdf
- GMAT逻辑因果关系答题方向补充知识-智课教育.pdf
- GMAT逻辑句子作用题解题方法-智课教育.pdf
- GMAT逻辑加强题解题方法-智课教育.pdf
- GMAT逻辑练习题及解析(一)-智课教育.pdf
- GMAT逻辑归纳推理题必要条件解析-智课教育.pdf
- GMAT阅读材料解析-智课教育.pdf
- 场地脚手架工程施工方案(3篇).docx
- 2024年浙江省丽水市松阳县玉岩镇招聘社区工作者真题及参考答案详解一套.docx
- 2024年河南省郑州市惠济区古荥镇招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市淳安县文昌镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省台州市三门县小雄镇招聘社区工作者真题带答案详解.docx
- 2024年浙江省宁波市余姚市河姆渡镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省丽水市景宁畲族自治县雁溪乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市临安市板桥乡招聘社区工作者真题及答案详解一套.docx
- 2024年湖北省宜昌市点军区土城乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省台州市路桥区桐屿街道招聘社区工作者真题附答案详解.docx
最近下载
- 鲁教版初中八年级的上册英语短语句型.docx VIP
- 新人教版高中数学选择性必修第一册全套PPT课件及配套讲义.pptx VIP
- 四川省拟任县处级试题 四川省拟任县处级党政领导干部任职资格考试题.doc VIP
- 鲁教版八年级上册英语短语句型.doc VIP
- 最新人教版(2023年新版)信息技术四年级上册(含课后反思).pdf VIP
- 2025年广东省广州市高二下学期期末考试物理(理)试卷Word版含答案 .pdf VIP
- 简单的个人简历模板.pdf VIP
- 上消化道穿孔教学查房.pptx VIP
- 科研方法论知到智慧树期末考试答案题库2025年南开大学.docx VIP
- 2023山西临汾市永和县招用公益性岗位人员50人笔试备考题库及答案解析.docx VIP
文档评论(0)