雖然非常不建議在數據庫中保存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也是可以操作這兩種數據類型的