虽然非常不建议在数据库中保存Blob和Clob类型的数据,但真的要有这样的需求呢?这里记录一下使用Hibernate如何向数据库中保存Blob和Clob数据。

Oracle和MySql在Blob类型上没什么区别,但是Mysql没有Clob类型,取而代之的是Text类型,所以这里还有点区别。BLOB在数据库中是以二进制的形式存在的,所以无法直接看到,如果是图片的话,使用一些数据库管理软件还是可以看到图片的,而CLOB就是大文本,可以直接就看到内容。

Oracle

这是一个名为Student的实体类:

package cn.entity;

import java.sql.Blob;
import java.sql.Clob; public class Student { private String stuid; private Blob stuimage; private Clob studesc; /*setter and getter*/ }

Student.hbm.xml:

<property name="stuimage"  type="blob"/>
<property name="studesc" type="clob"/>

使用Hibernate操作CLOB和BLOB:

@Test
public void saveBlobAndClob() {
try {
//123.jpg
InputStream in=new FileInputStream("d:\\123.jpg");
byte[] byteArray=new byte[in.available()];
in.read(byteArray);
in.close(); //新建文本文档.txt
InputStream in2=new FileInputStream("d:\\新建文本文档.txt");
byte[] byteArray2=new byte[in2.available()];
in2.read(byteArray2);
in2.close();
String string=new String(byteArray2); User user=new User();
user.setPhoto(Hibernate.createBlob(byteArray));
user.setInfo(Hibernate.createClob(byteArray2)); session.save(user); } catch (Exception e) {
e.printStackTrace();
}
}

这里主要是使用Hibernate的静态方法createBlob或createClob即可

MySql

mysql中并没有CLOB类型的数据,使用的Text类型,映射的Java类型使用String而不能再使用java.sql.Clob类型,

注意点有两个

User.java:(注意点一:使用String的Java类型)

package cn.entity;

import java.sql.Blob;

public class User {

    private Integer id;
private Blob photo;
private String info; /*setter and getter*/ }

User.hbm.xml:(注意点二:映射类型为text)

     <property name="photo" type="blob"></property>
<property name="info" type="text"/>

要使用text的type,而不是clob的type,不然会映射不成功

使用Hibernate操作CLOB和BLOB的代码和Oracle中的大致一样,不同之处在于使用string操作:

    @Test
public void saveBlobAndClob() {
try {
//123.jpg
InputStream in=new FileInputStream("d:\\123.jpg");
byte[] byteArray=new byte[in.available()];
in.read(byteArray);
in.close(); //新建文本文档.txt
InputStream in2=new FileInputStream("d:\\新建文本文档.txt");
InputStreamReader reader=new InputStreamReader(in2,"gbk");
char[] cbuf=new char[1024];
reader.read(cbuf);
reader.close(); User user=new User();
user.setPhoto(Hibernate.createBlob(in));
user.setInfo(new String(cbuf)); session.save(user); } catch (Exception e) {
e.printStackTrace();
}
}

读的操作

对于CLOB的读操作使用:

  • getCharacterStream()
  • getAsciiStream()

对于BLOB的读操作使用:

  • getBinaryStream()
  • getBytes(long pos, int length)

都是对应类中的方法,需要时可以查API,其实使用JDBC也可以操作这两种类型,PreparedStatement中都有对应方法,如

ps.setBinaryStream  操作BLOB

ps.setClob   操作CLOB类型的数据   
ps.setAsciiStream 使用流的方式处理CLOB(ASDII编码)
ps.setUnicodeStream 使用流的方式处理CLOB(Unicode编码)
ps.setCharacterStream 使用字符流处理CLOB 所以纯使用JDBC也是可以操作这两种数据类型的
												

Hibernate保存Blob和Clob类型的数据的更多相关文章

  1. Hibernate向数据库存入BLOB和CLOB类型的数据

    我选用的是byte[] +@Lob 刚开始采用的java.sql.Blob,将上传的图片getBytes()后,通过Hibernate.getLobCreator(HibernateSessionFa ...

  2. Oracle中Blob和Clob类型的区别与操作

    Oracle中Blob和Clob类型 1.Oracle中Blob和Clob类型的区别 BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的 ...

  3. 问题:oracle CLOB类型;结果:oracle中Blob和Clob类型的区别

    BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的的,或者可以直接用LOB字段代替这两个.但是为了更好的管理ORACLE数据库,通常像图 ...

  4. oracle中Blob和Clob类型的区别

    BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的的,或者可以直接用LOB字段代替这两个.但是为了更好的管理ORACLE数据库,通常像图 ...

  5. jsp页面struts2标签展示clob类型的数据

    直接从数据库中查出来的数据,是clob类型的在前端页面展示的时候是这样: 后来找到了一个方法,在action中添加一个方法,解析转换clob数据的方法 public String getClob(Cl ...

  6. hibernate的操作Blob和Clob类型数据(笔记)

  7. jsp里更新Clob类型字段数据

    ResultSet rs = null; Connection conn = new dbconn().getconnect(); Statement stmt = null; int news=0; ...

  8. Spring 让 LOB 数据操作变得简单易行,LOB 代表大对象数据,包括 BLOB 和 CLOB 两种类型

    转自:https://www.ibm.com/developerworks/cn/java/j-lo-spring-lob/index.html 概述 LOB 代表大对象数据,包括 BLOB 和 CL ...

  9. Hibernate二进制或大文件类型数据和Oracle交互

    //测试存储二进制文件 @Test public void test() throws IOException{  InputStream in=new FileInputStream("E ...

随机推荐

  1. 桔子桑Blog(小程序)V 0.4

    这两天对这个个人博客小程序的UI又作了一些补充,目前看来,小程序的主要功能如下: 1.博客/日常栏目的导航切换 为了避免两个模块的UI上的过于单一,我将两个模块的列表页作了区分: 边距是自适应的(针对 ...

  2. html2canvas 截屏 兼容手机端

    <template> <div> <!--<input type="button" id="btnsavaImg" valu ...

  3. VC dimension and Model complexity

    可以把growth function m_H(N)的upper bound用N^(k-1)来限制, for N large, k>=3 Thus, 定义: VC Dimension: maxim ...

  4. Ubuntu Kylin14.04下PHP环境的搭建(LAMP)

    1.首先打开命令行,切换到root身份,获得最新的软件包 su root sudo apt-get install update 2.安装MySQL数据库 sudo apt-get install m ...

  5. canvas 背景透明

    theCanvas = document.getElementById('canvasOne');var context = theCanvas.getContext('2d');context.fi ...

  6. JSP学习(四)JSP属性范围

    P属性范围 四种属性范围分别指以下四种: 当前页page:一个属性只能在一个页面中取得,跳转到其他页面无法取得 一次服务器请求request:一个页面中设置的属性,只要经过了服务器跳转,则跳转之后的页 ...

  7. 为什么 UEFI 方式启动的 U 盘必须使用 FAT32 文件系统?

    如果你希望更刺激地安装 Windows,那么你需要了解很多 Windows 系统相关的问题. 为什么 UEFI 方式启动的 U 盘必须使用 FAT32 文件系统? 因为 NTFS 是 Windows ...

  8. WPF 同一窗口内的多线程 UI(VisualTarget)

    WPF 的 UI 逻辑只在同一个线程中,这是学习 WPF 开发中大家几乎都会学习到的经验.如果希望做不同线程的 UI,大家也会想到使用另一个窗口来实现,让每个窗口拥有自己的 UI 线程.然而,就不能让 ...

  9. [LOJ6261]一个人的高三楼

    loj description 给你一个长度为\(n\)的数列\(a_i\),求它的\(k\)次前缀和模\(998244353\).(就是做\(k\)次前缀和后的数列) \(n\le10^5,k\le ...

  10. 关于matlab中定点数overflow的处理办法

    定点数overflow的处理有两种办法:1,saturate,也就是说如果超过定点的最大值就取最大值,例如最大值是6结果是8,那么就取6:2,wrap,就是循环,如下图所示