用spring的hibernateTemplate操作mysql blob

來源:互聯網
上載者:User

在網上搜了很多文章,發現要配置很多東東,而且,配置了也要報錯,筆者發現一個無需特殊配置的方法,操作很簡單,廢話不多說,看代碼:


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>即可

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.