Hibernate保存Blob和Clob类型的数据
虽然非常不建议在数据库中保存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类型的数据的更多相关文章
- Hibernate向数据库存入BLOB和CLOB类型的数据
我选用的是byte[] +@Lob 刚开始采用的java.sql.Blob,将上传的图片getBytes()后,通过Hibernate.getLobCreator(HibernateSessionFa ...
- Oracle中Blob和Clob类型的区别与操作
Oracle中Blob和Clob类型 1.Oracle中Blob和Clob类型的区别 BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的 ...
- 问题:oracle CLOB类型;结果:oracle中Blob和Clob类型的区别
BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的的,或者可以直接用LOB字段代替这两个.但是为了更好的管理ORACLE数据库,通常像图 ...
- oracle中Blob和Clob类型的区别
BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的的,或者可以直接用LOB字段代替这两个.但是为了更好的管理ORACLE数据库,通常像图 ...
- jsp页面struts2标签展示clob类型的数据
直接从数据库中查出来的数据,是clob类型的在前端页面展示的时候是这样: 后来找到了一个方法,在action中添加一个方法,解析转换clob数据的方法 public String getClob(Cl ...
- hibernate的操作Blob和Clob类型数据(笔记)
- jsp里更新Clob类型字段数据
ResultSet rs = null; Connection conn = new dbconn().getconnect(); Statement stmt = null; int news=0; ...
- Spring 让 LOB 数据操作变得简单易行,LOB 代表大对象数据,包括 BLOB 和 CLOB 两种类型
转自:https://www.ibm.com/developerworks/cn/java/j-lo-spring-lob/index.html 概述 LOB 代表大对象数据,包括 BLOB 和 CL ...
- Hibernate二进制或大文件类型数据和Oracle交互
//测试存储二进制文件 @Test public void test() throws IOException{ InputStream in=new FileInputStream("E ...
随机推荐
- Win10启动盘制作工具
Rufus https://rufus.akeo.ie/ http://www.iplaysoft.com/windows-10-udisk-install.html
- WIN7不能上网
http://zhidao.baidu.com/link?url=lYL0Sti_nX3JDz3pA3cVh49nyYDEQBJ6P5fxwB4La0FurHlgmWGMdgfMGjQSWxj17sH ...
- HAWQ + MADlib 玩转数据挖掘之(三)——向量
一.定义 这里不讨论向量严格的数学定义.在Madlib中,可以把向量简单理解为矩阵.矩阵是Madlib中数据的基本格式,当矩阵只有一维时,就是向量,1行n列的矩阵称为行向量,m行1列的矩阵称为列向量, ...
- java入门学习(4)— 类,对象理解,如何创建类,对象
1.什么是类?具有一定相同的属性的对象的集合就叫类.2.对象:类的具体实例,就是类的实例化.比如学生是一个类(student),那学生里面的小红就是一个对象,一个有学生的属性的对象.3.如何定义一个类 ...
- Android中的sp和wp指针
经常会在android的framework代码中发现sp<xxx>和wp<xxx>这样的指针,平时看的时候都把他当成一个普通的指针封装过掉了,这几天终于忍不住了,想深入了解一下 ...
- python pass关键字神奇吗
参考文献:http://blog.sina.com.cn/s/blog_76e94d210100vz3e.html 1.空语句 do nothing2.保证格式完整3.保证语义完整 好吧!它什么也没干 ...
- 【剑指offer】二叉树的子结构,C++实现(递归)
原创博文,转载请注明出处! <牛客链接> 1.题目 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:约定空树不是任意一个树的子结构) 图1.二叉树A和二叉树B 2.思路(递归) ...
- Android中的按键顺序打乱
首先要找到相对应的控件,之后再来一个数组,再把数组里面的数字显示到控件上面. private void initView() { mNum0 = (Button) findViewById(R.id. ...
- del语句的总结
删除属性 del 语句 可以删除对象(实例)的属性 语法: del 对象.实例变量名 del 语句 del 变量名 删除变量 del name del 列表[整数表达式] 删除列表中的元素 del L ...
- ExpressCache
ExpressCache 非联想.等品牌电脑使用的ExpressCache(带破解文件). (原始安装文件+patch+说明).注意,执行eccmd命令时,需要管理员权限.否则报错. http://a ...