用spring的hibernateTemplate操作mysql blob

在网上搜了很多文章,发现要配置很多东东,而且,配置了也要报错,笔者发现一个无需特殊配置的方法,操作很简单,废话不多说,看代码:


package com.czp.test;

public class BlobTest {

	 private int id;
	 private Object obj;//这里可以是任何对象
	 private byte[] bytes;
	 
	 
	public byte[] getBytes() {
		return bytes;
	}
	public void setBytes(byte[] bytes) {
		this.bytes = bytes;
	}
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public Object getObj() {
		return obj;
	}
	public void setObj(Object obj) {
		this.obj = obj;
	}
	 
}






package com.czp.test;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.sql.Blob;
import java.util.ArrayList;
import java.util.List;

import org.hibernate.Hibernate;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

public class BlobDao extends HibernateDaoSupport{
      
	/**
	 * 保存对象
	 * @param blobTest
	 * @throws Exception
	 */
	public void add(BlobTest blobTest) throws Exception
	{
		File file = File.createTempFile(blobTest.hashCode() + "", null);
		if (file != null) {
			ObjectOutputStream ob = new ObjectOutputStream(new FileOutputStream(file));
			ob.writeObject(blobTest.getObj());
			ob.flush();
			ob.close();
			ob = null;
			FileInputStream fis = new FileInputStream(file);
			byte[] b = new byte[fis.available()];
			fis.read(b);
			fis.close();
			blobTest.setBytes(b);
			this.getHibernateTemplate().save(blobTest);
	}
		
	}
	/**
	 * 获取对象
	 * @return
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	public List<BlobTest> getBlob() throws Exception
	{
		List<BlobTest> listtmp = new ArrayList<BlobTest>();
		List<BlobTest> list = this.getHibernateTemplate().loadAll(BlobTest.class);
		for (BlobTest blt : list) {
			Blob b = Hibernate.createBlob(blt.getBytes());
			ObjectInputStream ois = new ObjectInputStream(b.getBinaryStream());
			Object obj = ois.readObject();
			ois.close();
			ois = null;
			blt.setObj(obj);
			listtmp.add(blt);
			
		}
		return listtmp ;
		
	}
}
hibernate spring的配置省略,只需要将BlobTest的bytes属性在hibernate映射文件里映射为:<property name="bytes" type="binary" not-null="true" column="`XXXX`"></property>即可

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值