虽然非常不建议在数据库中保存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. New Concept English three(16)

    35w/m 43 Mary and her husband Dimitri lived in the tiny village of Perachora in southern Greece. One ...

  2. Html5的Web存储和WebSql

    HTML5 Web 存储 使用HTML5可以在本地存储用户的浏览数据. 早些时候,本地存储使用的是cookies.但是Web 存储需要更加的安全与快速. 这些数据不会被保存在服务器上,但是这些数据只用 ...

  3. (转)MapReduce Design Patterns(chapter 4 (part 1))(七)

    Chapter 4. Data Organization Patterns 与前面章节的过滤器相比,本章是关于数据重组.个别记录的价值通常靠分区,分片,排序成倍增加.特别是在分布式系统中,因为这能提高 ...

  4. 当创建SDL工程发现“无法解析的外部符号 _SDL_main”出错

    当你创建一个新控制台程序,想调用SDL时,编译时发现如下出错: 1>------ 已启动生成: 项目: caipal, 配置: Debug Win32 ------1>  caipal.c ...

  5. [QT]给QApplication安装事件过滤器 app.installEventFilter

    Qt的事件处理有5种级别: 1.      重写控件的事件处理函数:如重写keyPressEvent(),mousePressEvent()和paintEvent(),这是最常用的事件处理方法,我们已 ...

  6. 基于 od 窗口的anti

    虽然 odadvance 这类的插件 , 使用驱动将 od 的窗口 进行 隐藏,使用enumwindow ,无法枚举到od的窗口, 但是依然可以 使用r3 的方法 , 对od 窗口检测 之后可以使用 ...

  7. HDU - 6397:Character Encoding (组合数&容斥)

    题意:T组数据,给次给出N,M,K,多少种方案,用[0,N-1]范围的数,表示一个M排列,其和为K: 思路:隔板法,不限制[0,N-1]的时候答案是C(M+K-1,M-1):那么我们减去至少一个> ...

  8. hiho1613 墨水滴

    对不起,太弱了.................想了一下午

  9. Hadoop简介(1):什么是Map/Reduce

    看这篇文章请出去跑两圈,然后泡一壶茶,边喝茶,边看,看完你就对hadoop整体有所了解了. Hadoop简介 Hadoop就是一个实现了Google云计算系统的开源系统,包括并行计算模型Map/Red ...

  10. python(十二):网络编程之ISO/OSI模型

    互联网(Internet)是依据操作系统,在计算机硬件的基础上建立起的通讯机制.它依赖于TCP/IP协议栈. 一.ISO/OSI模型 1.ISO七层模型与OSI五层模型 它们将计算机抽象成了具有层级关 ...