虽然很是不建议在数据库中保存Blob和Clob类型的数据,但真的要有这样的需求呢?这里记录一下使用Hibernate如何向数据库中保存Blob和Clob数据。java
Oracle和MySql在Blob类型上没什么区别,可是Mysql没有Clob类型,取而代之的是Text类型,因此这里还有点区别。BLOB在数据库中是以二进制的形式存在的,因此没法直接看到,若是是图片的话,使用一些数据库管理软件仍是能够看到图片的,而CLOB就是大文本,能够直接就看到内容。mysql
这是一个名为Student的实体类:sql
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:session
@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便可ui
mysql中并无CLOB类型的数据,使用的Text类型,映射的Java类型使用String而不能再使用java.sql.Clob类型,编码
注意点有两个。spa
User.java:(注意点一:使用String的Java类型)code
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)xml
<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的读操做使用:
对于BLOB的读操做使用:
都是对应类中的方法,须要时能够查API,其实使用JDBC也能够操做这两种类型,PreparedStatement中都有对应方法,如
ps.setBinaryStream 操做BLOB
ps.setClob 操做CLOB类型的数据
ps.setAsciiStream 使用流的方式处理CLOB(ASDII编码)
ps.setUnicodeStream 使用流的方式处理CLOB(Unicode编码)
ps.setCharacterStream 使用字符流处理CLOB
因此纯使用JDBC也是能够操做这两种数据类型的