- 浏览: 7189239 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (397)
- 架构研究 (44)
- 网络协议-TCP/HTTP (20)
- SPRING (23)
- HIBERNATE 3 (30)
- STRUTS 2 (20)
- Java/J2se (25)
- Servlet/Jsp (9)
- 开发工具IDE (10)
- WEB服务器 (17)
- 前端--Java Script (33)
- 前端--CSS (7)
- OS--Linux (31)
- OS--MAC OS (19)
- MySQL数据库 (19)
- Oracle数据库 (11)
- 项目管理工具 (12)
- 数据报表技术 (4)
- 图像处理技术 (10)
- 其它综合技术 (13)
- 权限管理 (1)
- MyBatis (1)
- 网络安全 (6)
- IO (21)
- PostgreSQL (2)
- Eclipse RCP (1)
- GWT (1)
- 算法 (3)
- Storm (2)
- zookeeper (3)
- 消息 (1)
最新评论
-
bukebuhao:
已解决,打开文件太多。ulimit -n 上次临时生效后再次s ...
TFS(Taobao File System)配置dataServer、分区、挂载数据盘 -
bukebuhao:
ds重启后启动不了。报错信息如下,请大神帮助[2018-08- ...
TFS(Taobao File System)配置dataServer、分区、挂载数据盘 -
墨上清:
感谢,看完有了一个完整的知识网络。
Spring MVC 教程,快速入门,深入分析 -
云卷云舒灬:
谢谢,学到很多
Spring MVC 教程,快速入门,深入分析 -
luozhy:
非常感谢非常感谢
Project Web Access ActiveX控件 安装
Photo.java
Photo.hbm.xml
PhotoManagerImpl.java
其中继承了BaseDao类,这是一个通用Hibernate 泛型DAO工具类
BaseDaoBlobClobTest.java
其中用到了JUnitBase_svc类,作用是加载spring的配置文件
import java.sql.Blob; import java.sql.Clob; import java.util.Date; /** * @author IBM 这是一个用于测试Hibernate大对象操作的PO * * 这是一个测试POJO, 属性有多种类型 */ public class Photo { private Long id; private String fileName="";// 文件名 private Date date = new Date(); // 主库时间,默认值是当前时间 private Blob photo;// 相片的二进制形式,大对象 private Clob text;// 文字说明,大对象 private byte[] bin;//字节数组 }
Photo.hbm.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="test.com.base"> <class name="Photo" table="test_Photo"> <id name="id"> <generator class="native"/> </id> <property name="fileName" /> <property name="date" /> <property name="photo" /> <property name="text" /> <property name="bin" /> </class> </hibernate-mapping>
PhotoManagerImpl.java
其中继承了BaseDao类,这是一个通用Hibernate 泛型DAO工具类
package test.com.base; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; import java.io.OutputStream; import java.io.Reader; import java.nio.CharBuffer; import java.sql.Clob; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import com.base.dao.BaseDao; @Transactional @Service public class PhotoManagerImpl extends BaseDao<Photo,Long> { //空 }
BaseDaoBlobClobTest.java
其中用到了JUnitBase_svc类,作用是加载spring的配置文件
package test.com.base; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.io.Reader; import java.sql.Blob; import java.sql.Clob; import javax.annotation.Resource; import org.hibernate.Hibernate; import org.hibernate.LockMode; import org.hibernate.Session; import org.hibernate.Transaction; import org.junit.Test; import com.base.dao.BaseDao; /** * 通过个单元测试,演示了<br/> * 1: 如何操作大象<br/> * 2:懒加载的一种解决方案<br/> */ public class BaseDaoBlobClobTest extends JUnitBase_svc { @Resource private PhotoManagerImpl photoManagerImpl; /** * 测试保存大对象 */ @Test public void TestSaveBlob() { // ----------456.jpg 转成Blob-------------------- InputStream in = this.getClass().getResourceAsStream("phtot.jpg"); Blob blob = null; try { blob = Hibernate.createBlob(in); } catch (IOException e) { e.printStackTrace(); } // ----------文字 转成Clob-------------------- Clob clob = Hibernate.createClob("文字 转成Clob"); // ------------------------------------------ Photo photo = new Photo(); photo.setFileName("haha.jpg"); photo.setPhoto(blob); photo.setText(clob); photoManagerImpl.save(photo); } /** * 测试取得大对象,没有使用懒加载, */ @Test public void TestGetBlob() { Photo photo = photoManagerImpl.get(3L);// 执行Hibername的get方法,会马上执行SQL查询 int len = 0; byte[] buf = new byte[1024]; try { String path = "d:\\abc.jpg";// 取出图片后保存的位置 InputStream in = photo.getPhoto().getBinaryStream(); OutputStream out = new FileOutputStream(new File(path)); while ((len = in.read(buf)) > 0) { out.write(buf, 0, len); } out.close(); in.close(); System.out.println("读出的图片放在了:" + path); Clob clob = photo.getText(); Reader reader = clob.getCharacterStream(); char[] cb = new char[1024]; StringBuffer sb = new StringBuffer(); len = 0; while ((len = reader.read(cb)) > 0) { sb.append(cb, 0, len); } System.out.println(sb.toString()); } catch (Exception e) { e.printStackTrace(); } } /** * 测试取得大对象,使用了懒加载, * * 并且是在事务已提交,session已关闭后才通过Hibernate代理查出的目标对象 * * 这是懒加载的一种解决方案,很重要,特此说明 */ @Test public void TestLoadBlob() { // 执行的是load方法,会延迟加载,返回Hibernate代理对象之后session已关闭 Photo photo = photoManagerImpl.load(3L); //打开一个新Session,不能使用getCurrentSession()方法 Session session = photoManagerImpl.getNewSession(); System.out.println("Session是打开的吗:"+session.isOpen()); // 把Hibernate代理对象重新关联到一个session对象 session.lock(photo, LockMode.NONE); //开启事务 Transaction t=session.beginTransaction(); int len = 0; byte[] buf = new byte[1024]; try { String path = "d:\\abc.jpg";// 取出图片后保存的位置 //这时才发出sql语句,执行查询,达到了懒加载的目的 InputStream in = photo.getPhoto().getBinaryStream(); OutputStream out = new FileOutputStream(new File(path)); while ((len = in.read(buf)) > 0) { out.write(buf, 0, len); } out.close(); in.close(); System.out.println("读出的图片放在了:" + path); Clob clob = photo.getText(); Reader reader = clob.getCharacterStream(); char[] cb = new char[1024]; StringBuffer sb = new StringBuffer(); len = 0; while ((len = reader.read(cb)) > 0) { sb.append(cb, 0, len); } ; System.out.println(sb.toString()); } catch (Exception e) { e.printStackTrace(); } System.out.println(t==session.getTransaction()); //提交事务 session.getTransaction().commit(); //关闭 session.close(); } }
发表评论
-
Hibernate二级缓存 ---- 最佳实践
2010-11-08 10:17 39285作者:赵磊 博客:ht ... -
Hibernate--泛型DAO
2010-06-27 19:49 5052泛型DAO(翻译) http://www.iteye.com ... -
Hibernate--空位
2010-06-27 15:41 1796原文章已合并整理到: http://elf8848.itey ... -
Hibernate二级缓存 ---- 入门示例
2010-06-27 15:34 4149一. 我们使用oscache来演示 , 引入oscache的j ... -
Hibernate ---- 控制日志
2010-06-06 11:46 3043Hibernate版本 3.3或3.4 Hibernate ... -
Hibernate悲观锁定与乐观锁定
2010-05-17 15:08 2241悲观锁定 由数据库方面实现. 可见:Hibernate悲观锁 ... -
Hibernate懒加载深入分析
2010-05-14 11:22 8282[size=small] ------------------ ... -
Hibernate批量操作(JDBC批量操作)
2009-03-30 14:52 8402部分内容转自 :http://ga ... -
Hibernate分页查询与泛型
2009-03-26 19:03 7358JE有两篇文章,关于分页查询 与泛型 的,写的很好.这里收藏一 ... -
20 Hibernate 1+N问题的原理与解决
2009-03-04 09:44 13076什么时候会遇到1+N的问题? 前提:Hibernate默认表 ... -
19 Criteria查询,DetachedCriteria离线查询 --做综合查询
2009-03-04 09:35 3732通过Session得到Criteria类的对象 /** ... -
空位空位
2009-03-03 10:22 2333空位空位空位空位 -
17 继承(四)每一个具体的类 映射到一张表
2009-03-02 13:54 2297类(Person) , 男人(Men)继 ... -
16 继承(三)(把前面14,15讲的情况结合起来)
2009-03-02 13:30 2091人类(Person) , 男人(Men)继承"人& ... -
15 继承(二)(每个子类扩展的属性单独保存在一张表中)
2009-03-02 13:07 2069人类(Person) , 男人(Men)继承" ... -
14 继承(一)(整个继承树映射到一张表)
2009-03-02 11:00 2225人类(Person) , 男人(Men)继承" ... -
13 级联和关系维护(Cascade 和Inverse)
2009-03-01 17:58 3039Cascade用来说明当对主对象进行某操作时, 是否对其关联的 ... -
12 映射-- 集合类的映射(Set,List,Map,Array)
2009-03-01 16:18 2621部门类Department , 他有 empa1, emp ... -
11 映射-- 组件映射(人类与姓名类)
2009-03-01 15:26 2360User类: 注意他的name属性 package ... -
10 映射-- 多对多(老师与学生)
2009-03-01 15:01 2576学生类: package dao.po; impo ...
相关推荐
同时,确保数据库支持高效的BLOB和CLOB操作,比如Oracle的BFILE类型或使用流式处理。 总之,Hibernate提供了对BLOB和CLOB的便利支持,允许开发者在Java应用中轻松地处理大数据对象,从而实现与数据库的高效交互。...
在Java中,Blob和Clob是JDBC API提供的接口,但在Hibernate中,我们可以通过Session对象的save()或saveOrUpdate()方法来操作这些大数据对象。 首先,我们需要在实体类中定义对应的属性。例如,对于一个包含图片信息...
在Java Web开发中,...本文将详细介绍如何在Hibernate中操作Blob和Clob字段,实现数据的存储与读取。 首先,我们需要在Hibernate映射文件(.hbm.xml)中定义Blob和Clob字段。对于Blob,可以这样声明: ```xml ...
hibernate Blob、Clob字段的映射的例子.数据库mysql,数据库放在文件夹里面,例子的说明文章在我的csdn blog: http://blog.csdn.net/zhengcandan
这篇博客文章“Hibernate操作Oracle中Clob、Blob字段小结”可能会探讨如何在Hibernate中有效地处理这两种类型的数据。 1. **Clob与Blob的理解**: - Clob:Clob是用于存储大量字符数据的类型,例如长篇文章、XML...
在保存或更新带有Clob和Blob字段的实体时,Hibernate会自动处理这些数据的插入和更新操作。例如,当你调用`session.saveOrUpdate(entity)`或`entityManager.persist(entity)`时,Hibernate会将Clob和Blob的内容正确...
综上所述,使用Hibernate和JDBC读取Oracle数据库中的Blob数据涉及多个步骤,包括实体类的设计、数据库操作和文件流的处理。理解这些知识点对于处理大对象存储至关重要。在实际项目中,根据需求和性能考虑,选择合适...
Blob imageData = Hibernate.createBlob(fis); // 或者使用数据库驱动提供的Blob实现 Blob imageData = connection.createBlob(); imageData.setBinaryStream(1, fis, (int) imageFile.length()); ``` 4. **...
这篇博客“使用Jdbc4操作Blob,Clob”将深入讲解如何利用JDBC4 API来处理Blob和Clob对象。 Blob通常用于存储二进制数据,如图片、音频或视频文件,而Clob则用于存储大量文本数据,如长篇的文本或XML文档。在JDBC4中...
### Spring与Hibernate处理大字段(CLOB/BLOB) 在企业级应用开发中,经常会遇到需要存储大量文本或二进制数据的情况,这时就需要用到数据库的大字段类型如CLOB(Character Large Object)和BLOB(Binary Large ...
在本示例中,我们将探讨如何使用Oracle数据库、Hibernate ORM框架以及Uploadify插件处理Blob类型的大数据,如图片或文件上传。Blob(Binary Large Object)是数据库中用于存储二进制大对象的类型,常用于存储图片、...
Spring和Hibernate框架结合使用可以有效地进行CLOB字段的操作。以下是实现这一功能的关键步骤和注意事项: 1. **配置SessionFactory** 在Spring配置文件中,你需要创建一个`SessionFactory` bean,同时指定一个`...
- 使用Blob/Clob接口:直接操作Clob接口进行读写,而不是将其转换为字符串或其他数据类型,以减少转换开销。 通过以上内容,你应该对在Hibernate中动态映射Oracle 10g的CLOB类型有了深入理解,这将帮助你在实际...
总结来说,Blob和Clob是数据库中存储大对象的关键工具,它们在Hibernate中提供了方便的接口用于操作这些数据。在Microsoft SQL Server环境下,Hibernate能够无缝地将Java对象与Blob和Clob类型的数据库字段对应起来,...
2. **预编译SQL语句**:Blob和Clob操作通常涉及预编译的PreparedStatement,因为它们通常需要动态插入或更新大数据值。例如,`PreparedStatement.setBlob(int index, Blob value)` 和 `PreparedStatement.setClob...
此外,还要注意数据库的性能,比如使用BLOB而非CLOB,根据数据的性质选择更合适的存储方式。 总的来说,理解和掌握Clob在Hibernate中的应用对于开发处理大文本数据的系统至关重要。通过合理的配置和使用,可以有效...