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也是可以操作這兩種數據類型的
 
       


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM