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也是可以操作这两种数据类型的

posted @   OverZeal  阅读(4561)  评论(1编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 【杂谈】分布式事务——高大上的无用知识?
点击右上角即可分享
微信分享提示

目录

目录

X