`

Hibernate 操作Blob Clob

阅读更多
Photo.java
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对BLOB CLOB操作

    同时,确保数据库支持高效的BLOB和CLOB操作,比如Oracle的BFILE类型或使用流式处理。 总之,Hibernate提供了对BLOB和CLOB的便利支持,允许开发者在Java应用中轻松地处理大数据对象,从而实现与数据库的高效交互。...

    hibernate保存blob,clob对象

    在Java中,Blob和Clob是JDBC API提供的接口,但在Hibernate中,我们可以通过Session对象的save()或saveOrUpdate()方法来操作这些大数据对象。 首先,我们需要在实体类中定义对应的属性。例如,对于一个包含图片信息...

    Hibernate对Blob,Clob的操作

    在Java Web开发中,...本文将详细介绍如何在Hibernate中操作Blob和Clob字段,实现数据的存储与读取。 首先,我们需要在Hibernate映射文件(.hbm.xml)中定义Blob和Clob字段。对于Blob,可以这样声明: ```xml ...

    hibernate Blob、Clob字段的映射的例子

    hibernate Blob、Clob字段的映射的例子.数据库mysql,数据库放在文件夹里面,例子的说明文章在我的csdn blog: http://blog.csdn.net/zhengcandan

    Hibernate操作Oarcle中Clob、Blob字段小结

    这篇博客文章“Hibernate操作Oracle中Clob、Blob字段小结”可能会探讨如何在Hibernate中有效地处理这两种类型的数据。 1. **Clob与Blob的理解**: - Clob:Clob是用于存储大量字符数据的类型,例如长篇文章、XML...

    关于在Hibernate中对于Clob,Blob字段的处理方法

    在保存或更新带有Clob和Blob字段的实体时,Hibernate会自动处理这些数据的插入和更新操作。例如,当你调用`session.saveOrUpdate(entity)`或`entityManager.persist(entity)`时,Hibernate会将Clob和Blob的内容正确...

    使用hibernate对oracle读取blob

    综上所述,使用Hibernate和JDBC读取Oracle数据库中的Blob数据涉及多个步骤,包括实体类的设计、数据库操作和文件流的处理。理解这些知识点对于处理大对象存储至关重要。在实际项目中,根据需求和性能考虑,选择合适...

    java将图片写入数据库,并读出来(blob clob)

    Blob imageData = Hibernate.createBlob(fis); // 或者使用数据库驱动提供的Blob实现 Blob imageData = connection.createBlob(); imageData.setBinaryStream(1, fis, (int) imageFile.length()); ``` 4. **...

    使用Jdbc4操作Blob,Clob

    这篇博客“使用Jdbc4操作Blob,Clob”将深入讲解如何利用JDBC4 API来处理Blob和Clob对象。 Blob通常用于存储二进制数据,如图片、音频或视频文件,而Clob则用于存储大量文本数据,如长篇的文本或XML文档。在JDBC4中...

    spring+hibernate 解决大字段(clob)

    ### Spring与Hibernate处理大字段(CLOB/BLOB) 在企业级应用开发中,经常会遇到需要存储大量文本或二进制数据的情况,这时就需要用到数据库的大字段类型如CLOB(Character Large Object)和BLOB(Binary Large ...

    oracle+hibernate 处理blob +uploadify实例

    在本示例中,我们将探讨如何使用Oracle数据库、Hibernate ORM框架以及Uploadify插件处理Blob类型的大数据,如图片或文件上传。Blob(Binary Large Object)是数据库中用于存储二进制大对象的类型,常用于存储图片、...

    spring+hibernate操作oracle的clob字段

    Spring和Hibernate框架结合使用可以有效地进行CLOB字段的操作。以下是实现这一功能的关键步骤和注意事项: 1. **配置SessionFactory** 在Spring配置文件中,你需要创建一个`SessionFactory` bean,同时指定一个`...

    hibernate动态映射表处理oracle的clob类型

    - 使用Blob/Clob接口:直接操作Clob接口进行读写,而不是将其转换为字符串或其他数据类型,以减少转换开销。 通过以上内容,你应该对在Hibernate中动态映射Oracle 10g的CLOB类型有了深入理解,这将帮助你在实际...

    Blob和Clob使用例子

    总结来说,Blob和Clob是数据库中存储大对象的关键工具,它们在Hibernate中提供了方便的接口用于操作这些数据。在Microsoft SQL Server环境下,Hibernate能够无缝地将Java对象与Blob和Clob类型的数据库字段对应起来,...

    jdbc_blob_clob.rar

    2. **预编译SQL语句**:Blob和Clob操作通常涉及预编译的PreparedStatement,因为它们通常需要动态插入或更新大数据值。例如,`PreparedStatement.setBlob(int index, Blob value)` 和 `PreparedStatement.setClob...

    关于Clob类型在Hibernate中 的应用小结

    此外,还要注意数据库的性能,比如使用BLOB而非CLOB,根据数据的性质选择更合适的存储方式。 总的来说,理解和掌握Clob在Hibernate中的应用对于开发处理大文本数据的系统至关重要。通过合理的配置和使用,可以有效...

Global site tag (gtag.js) - Google Analytics