`
一场雨
  • 浏览: 48007 次
  • 性别: Icon_minigender_2
  • 来自: 深圳
社区版块
存档分类
最新评论

Hibernate保存Oracle大对象blob

阅读更多

import java.sql.Blob;
import net.sf.hibernate.*;
import oracle.sql.*;
import java.io.*;

public class TestCatHibernate { 
  public static void testBlob() {
    Session s = null;   
    byte[] buffer = new byte[];
    buffer[0] = 1;
    try {
      SessionFactory sf = HibernateSessionFactory.getSessionFactory();
      s = sf.openSession(); 
      Transaction tx = s.beginTransaction();
      Cat c = new Cat();
      c.setName("Robbin");
      c.setImage(Hibernate.createBlob(buffer));
      s.save(c);
      s.flush();

      s.refresh(c, LockMode.UPGRADE);   
      BLOB blob = (BLOB) c.getImage();     
      OutputStream out = blob.getBinaryOutputStream();  
      String fileName = "oraclejdbc.jar";
      File f = new File(fileName);
      FileInputStream fin = new FileInputStream(f);  
      int count = -1, total = 0;
      byte[] data = new byte((int)fin.available());
      fin.read(data);
      out.write(data);     
      fin.close();
      out.close();
      s.flush();
      tx.commit();
  
    } catch (Exception e) {
      System.out.println(e.getMessage());
    } finally {
      if (s != null)
        try {
          s.close();
        } catch (Exception e) {}
    }   
   
  }
}

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics