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();
分享到:
相关推荐
### Hibernate 对 Blob 类型字段进行数据添加 #### 知识点概述 在处理数据库操作时,经常需要存储二进制大对象(Binary Large Object,简称 BLOB),例如图像、视频等非文本数据。BLOB 类型是数据库系统中用于存储...
在Java的持久化框架Hibernate中,BLOB和CLOB是用来处理大数据对象(Binary Large Object和Character Large Object)的。这两个类型常用于存储图像、视频、大文本等数据,因为它们可以容纳超过数据库标准列大小限制的...
在Oracle数据库中,BLOB类型的字段具有特殊的处理方式,尤其在使用JDBC(Java Database Connectivity)和Hibernate框架时,需要特别注意其写入过程。以下是对“JDBC+Hibernate将Blob数据写入Oracle”这一主题的深入...
3. **读取Blob数据** 当我们需要从数据库中读取Blob字段时,通常会通过Session对象执行查询。以下是一个示例: ```java Session session = HibernateUtil.getSessionFactory().openSession(); Transaction ...
在Java的持久化框架Hibernate中,Blob和Clob对象是用来处理大数据类型的,它们分别对应数据库中的BLOB(Binary Large Object)和CLOB(Character Large Object)。这篇文章将详细讲解如何在Hibernate中保存这两种...
Hibernate作为一款流行的ORM(对象关系映射)框架,提供了与Oracle数据库交互的简便方式,包括处理Blob数据。本文将详细介绍如何使用Hibernate和JDBC读取和存储Oracle数据库中的Blob对象。 ### 1. Hibernate Blob...
在Java Web开发中,...本文将详细介绍如何在Hibernate中操作Blob和Clob字段,实现数据的存储与读取。 首先,我们需要在Hibernate映射文件(.hbm.xml)中定义Blob和Clob字段。对于Blob,可以这样声明: ```xml ...
<property name="photo" type="org.springframework.orm.hibernate3.support.BlobByteArrayType"> </hibernate-mapping> ``` 接下来,我们关注上传过程的Java代码。这里使用了`ServletFileUpload`类,它是...
3. **插入空BLOB**:使用`PreparedStatement`的`executeUpdate()`方法执行SQL插入语句,如`"insert into javatest(name,content) values(?,empty_blob())"`。这里的`empty_blob()`是Oracle提供的函数,用于在新记录...
在Java的持久化框架Hibernate中,处理大数据类型如Clob(Character Large Object)和Blob(Binary Large Object)是常见的需求,这些数据类型通常用于存储大量的文本或二进制数据。Oracle数据库提供了支持Clob和Blob...
3. **操作Clob和Blob**: - 插入数据:在保存实体时,Hibernate会自动处理Clob和Blob对象的序列化。可以通过`getClob()`和`setClob()`方法设置和获取Clob值,对于Blob,使用`getBlob()`和`setBlob()`。 - 更新数据...
总结来说,无论是通过JDBC还是Hibernate,写入Oracle数据库的Blob字段都需要先创建一个空Blob,然后获取其cursor,最后将二进制数据写入Blob。在JDBC中,这个过程涉及多个SQL语句和流操作;而在Hibernate中,通过ORM...
在实际操作中,可以通过Hibernate实现Oracle数据库中BLOB数据的存储和删除操作,然后利用Struts2框架展示这些BLOB数据。这样的结合,不仅可以提高开发效率,还能保证应用的性能和稳定性。 ### 实际操作步骤 在实际...
hibernate Blob、Clob字段的映射的例子.数据库mysql,数据库放在文件夹里面,例子的说明文章在我的csdn blog: http://blog.csdn.net/zhengcandan
总结起来,"spring mvc+hibernate 图片存储至blob"这个主题涉及到Spring MVC处理文件上传、Hibernate将图片数据存入数据库BLOB字段、以及前后端交互等多个技术点。通过理解这些知识点,开发者可以构建一个完整的图片...