`
biekwo
  • 浏览: 37568 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

hibernate3 blob

阅读更多
hibernate作为一个优秀的OR-Mapping构架,对数据库的基本操作进行了比较好的封装,针对Blob类型字段的操作也不例外。但网上大部分能找到的hibernate操作Blob的例程都是基于hibernate2版本的,同时在实际操作中我发现针对不同的数据库,可以有不同的操作方法。下面将hibernate3操作oracle的Blob字段进行一个介绍。
         用JDBC操作Blob最基本的思路是:先插入一条包含空Blob的记录,然后立即将该条记录用行锁定的方式打开,得到改Blob字段的引用,从中得到一个输出流,将byte[]数据写入后提交。hibernate操作的基本思路也是一致的。下例中用到表img,里面一个主键id,一个Blob字段img。它对应的映射文件如下:
 
      <class name="Img" table="IMG">
          <id name="id" column="ID" type="long">
              <generator class="increment"/>
          </id>
          <property name="img" column="IMG" type="java.sql.Blob" />        1
      </class>

         在1处可以不指定字段的类型,让hibernate自动处理。对应的持久化类中,img属性也声明为java.sql.Blob类型。插入的代码如下:
 
    Session s = Hsf.currentSession();
    Transaction t = s.beginTransaction();
    Img img = new Img();
  //调用Hibernate的静态方法,创建一个长度为1的byte数组,生成一个空Blob
    img.setImg(Hibernate.createBlob(new byte[1]));
    s.save(img);  //保存到数据库中
    s.flush();
    s.refresh(img,LockMode.UPGRADE);  //锁定为更新模式
    //System.out.println(img.getImg().getClass());
  //返回的是SerializableBlob类型的对象,这是个实现了Blob接口的对象,但不能直接造型为BLOB
    SerializableBlob sb = (SerializableBlob)img.getImg();
  //需要调用它的getWrappedBlob造型出来
    BLOB blob = (BLOB)sb.getWrappedBlob();
  //将某个文件读入后,写到Blob字段的输出流中
    OutputStream os = blob.getBinaryOutputStream();
    FileInputStream fis = new FileInputStream("a.jpg");
    byte[] buff = new byte[fis.available()];
    fis.read(buff);
    fis.close();
    os.write(buff);
    os.close();
    s.flush();
    t.commit();
    Hsf.closeSession();
 
       在操作中要注意的是,要进行写的操作,必须将类型强制造型为oracle.sql.BLOB,而用img.getImg()方法返回的对象的类型是org.hibernate.lob.SerializableBlob类型,该类型与oracle.sql.BLOB类型没有直接关系,所以不能直接强制造型。需要先造型为SerializableBlob,然后调用它的getWrappedBlob方法得到BLOB类型的对象。

       对应的读Blob的方法要简单一些,从Blob中直接得到输入流进行操作。代码如下:
 
     Session s = Hsf.currentSession();
    Img img = (Img)(s.createQuery("from Img order by id desc").iterate().next());
    InputStream is = img.getImg().getBinaryStream();
    OutputStream os = new FileOutputStream("b.jpg");
    //通过is.available()得不到总长度
    byte[] buff = new byte[1024];
    int i = 0;
    while((i=is.read(buff))!=-1){
     os.write(buff,0,i);
    }
    is.close();
    os.close();
    Hsf.closeSession();
分享到:
评论
4 楼 bobozuyuan 2013-05-10  
    OutputStream os = blob.getBinaryOutputStream();
    FileInputStream fis = new FileInputStream("a.jpg");
    byte[] buff = new byte[fis.available()];
    fis.read(buff);
    fis.close();
    os.write(buff);
    os.close();

这点调用写不出来
请参考
http://blog.sina.com.cn/s/blog_4ad7c254010006zn.html
3 楼 JEBAIKEjava2012 2012-06-15  
嗯,最近在使用oracle的blob字段保存大文本。学习了,准备试一试。
2 楼 JEBAIKEjava2012 2012-06-15  
   [color=yellow][/color][align=left][/align]
1 楼 hehaiztc 2010-12-17  
不错 ,就是由于这个“,必须将类型强制造型为oracle.sql.BLOB,而用img.getImg()方法返回的对象的类型是org.hibernate.lob.SerializableBlob类型”,调错调了好久,多谢!

相关推荐

    hibernate对Blob类型字段进行数据添加.txt

    ### Hibernate 对 Blob 类型字段进行数据添加 #### 知识点概述 在处理数据库操作时,经常需要存储二进制大对象(Binary Large Object,简称 BLOB),例如图像、视频等非文本数据。BLOB 类型是数据库系统中用于存储...

    Hibernate对BLOB CLOB操作

    在Java的持久化框架Hibernate中,BLOB和CLOB是用来处理大数据对象(Binary Large Object和Character Large Object)的。这两个类型常用于存储图像、视频、大文本等数据,因为它们可以容纳超过数据库标准列大小限制的...

    JDBC+Hibernate将Blob数据写入Oracle

    在Oracle数据库中,BLOB类型的字段具有特殊的处理方式,尤其在使用JDBC(Java Database Connectivity)和Hibernate框架时,需要特别注意其写入过程。以下是对“JDBC+Hibernate将Blob数据写入Oracle”这一主题的深入...

    Hibernate读取blob字段

    3. **读取Blob数据** 当我们需要从数据库中读取Blob字段时,通常会通过Session对象执行查询。以下是一个示例: ```java Session session = HibernateUtil.getSessionFactory().openSession(); Transaction ...

    hibernate保存blob,clob对象

    在Java的持久化框架Hibernate中,Blob和Clob对象是用来处理大数据类型的,它们分别对应数据库中的BLOB(Binary Large Object)和CLOB(Character Large Object)。这篇文章将详细讲解如何在Hibernate中保存这两种...

    使用hibernate对oracle读取blob

    Hibernate作为一款流行的ORM(对象关系映射)框架,提供了与Oracle数据库交互的简便方式,包括处理Blob数据。本文将详细介绍如何使用Hibernate和JDBC读取和存储Oracle数据库中的Blob对象。 ### 1. Hibernate Blob...

    Hibernate对Blob,Clob的操作

    在Java Web开发中,...本文将详细介绍如何在Hibernate中操作Blob和Clob字段,实现数据的存储与读取。 首先,我们需要在Hibernate映射文件(.hbm.xml)中定义Blob和Clob字段。对于Blob,可以这样声明: ```xml ...

    oracle+hibernate 处理blob +uploadify实例

    &lt;property name="photo" type="org.springframework.orm.hibernate3.support.BlobByteArrayType"&gt; &lt;/hibernate-mapping&gt; ``` 接下来,我们关注上传过程的Java代码。这里使用了`ServletFileUpload`类,它是...

    jdbc+hibernate存取blob字段

    3. **插入空BLOB**:使用`PreparedStatement`的`executeUpdate()`方法执行SQL插入语句,如`"insert into javatest(name,content) values(?,empty_blob())"`。这里的`empty_blob()`是Oracle提供的函数,用于在新记录...

    关于在Hibernate中对于Clob,Blob字段的处理方法

    在Java的持久化框架Hibernate中,处理大数据类型如Clob(Character Large Object)和Blob(Binary Large Object)是常见的需求,这些数据类型通常用于存储大量的文本或二进制数据。Oracle数据库提供了支持Clob和Blob...

    Hibernate操作Oarcle中Clob、Blob字段小结

    3. **操作Clob和Blob**: - 插入数据:在保存实体时,Hibernate会自动处理Clob和Blob对象的序列化。可以通过`getClob()`和`setClob()`方法设置和获取Clob值,对于Blob,使用`getBlob()`和`setBlob()`。 - 更新数据...

    使用JDBC和Hibernate来写入Blob型数据到Oracle中

    总结来说,无论是通过JDBC还是Hibernate,写入Oracle数据库的Blob字段都需要先创建一个空Blob,然后获取其cursor,最后将二进制数据写入Blob。在JDBC中,这个过程涉及多个SQL语句和流操作;而在Hibernate中,通过ORM...

    Struts2 Hibernate存取Oracle数据库中的BLOB数据.pdf

    在实际操作中,可以通过Hibernate实现Oracle数据库中BLOB数据的存储和删除操作,然后利用Struts2框架展示这些BLOB数据。这样的结合,不仅可以提高开发效率,还能保证应用的性能和稳定性。 ### 实际操作步骤 在实际...

    hibernate Blob、Clob字段的映射的例子

    hibernate Blob、Clob字段的映射的例子.数据库mysql,数据库放在文件夹里面,例子的说明文章在我的csdn blog: http://blog.csdn.net/zhengcandan

    spring mvc+hibernate 图片存储至blob

    总结起来,"spring mvc+hibernate 图片存储至blob"这个主题涉及到Spring MVC处理文件上传、Hibernate将图片数据存入数据库BLOB字段、以及前后端交互等多个技术点。通过理解这些知识点,开发者可以构建一个完整的图片...

Global site tag (gtag.js) - Google Analytics