用spring的hibernateTemplate操作mysql blob
来源:互联网 发布:html页面嵌入php 编辑:程序博客网 时间:2024/06/06 03:15
在网上搜了很多文章,发现要配置很多东东,而且,配置了也要报错,笔者发现一个无需特殊配置的方法,操作很简单,废话不多说,看代码:
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>即可
- 用spring的hibernateTemplate操作mysql blob
- Spring的HibernateTemplate用法
- hibernate操作mysql的blob数据
- MySQL 中 Blob的存取操作
- spring ibatis 操作BLOB
- mysql操作blob经验谈
- mysql操作blob
- mysql操作BLOB字段
- spring 中HibernateTemplate的使用
- spring+hibernate--HibernateTemplate的使用
- spring应用hibernateTemplate的配置
- Spring 的HibernateTemplate 支持配置
- Ibatis + Spring 操作 Blob 详解
- Ibatis + Spring 操作 Blob 详解
- oracle里BLOB字段的HIBERNATE,spring操作访问
- Struts2+Hibernate+Spring 在mysql更新Blob类型的数据
- Spring的HibernateDaoSupport DaoSupport用HibernateTemplate,JdbcTemplate详解
- Spring的HibernateDaoSupport DaoSupport用HibernateTemplate,JdbcTemplate详解
- Guice(二)
- Guice(三)
- 在不同模块分配和释放内存时出错的原因
- 开发宝典:数据库设计技巧,你知道几个?
- void value not ignore
- 用spring的hibernateTemplate操作mysql blob
- Javascript中的线程以及获取动态Dom元素的问题--thread/appendChild/setTimeout
- linux学习必备!《目录结构总结》
- spring与guice的区别
- Java,Android常用包介绍
- Spring注解注入
- DLL中用malloc分配了一块内存,但是在exe程序中释放引发的错误可能原因
- text-overflow:ellipsis,让溢出文本显示省略号
- Js 分享