Hibernate保存Oracle大对象blob

本文演示了如何使用 Hibernate 框架操作数据库中的 Blob 数据类型。通过一个具体的例子,展示了创建 Blob 对象、保存到数据库以及从数据库读取 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) {}
    }   
   
  }
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值