📄 摘要
在某些业务场景中,我们可能需要将图片、PDF 等二进制内容临时封装为 BLOB 对象以便后续传输或格式兼容操作,但此时我们并不打算连接数据库,或者只是单纯为了和某些接口或类进行交互。本文将介绍如何使用 javax.sql.rowset.serial.SerialBlob
类,轻松实现字节数组向 BLOB 对象的转换,无需依赖数据库连接。
🧠 为什么不直接用 oracle.sql.BLOB?
oracle.sql.BLOB
是专用于 Oracle JDBC 驱动的 BLOB 类型,使用时必须依赖数据库连接(Connection)。但在很多情况下,我们只是希望:
-
暂存一个 BLOB 对象;
-
与某些只接受
java.sql.Blob
类型的方法兼容; -
不想引入冗余数据库连接。
这时候,SerialBlob
就是我们最好的选择。
✅ SerialBlob 简介
SerialBlob
是 Java 提供的一个序列化 BLOB 实现,属于 javax.sql.rowset.serial
包。
它实现了
java.sql.Blob
接口,可用于程序中独立操作 BLOB 对象,不依赖任何数据库连接。
🔨 示例代码:Base64字符串转BLOB对象
import javax.sql.rowset.serial.SerialBlob;
import java.sql.Blob;
import java.util.Base64;
public class BlobExample {
public static Blob base64ToBlob(String base64Str) throws Exception {
// 解码 Base64 为字节数组
byte[] imageBytes = Base64.getDecoder().decode(base64Str);
// 将字节数组转为 BLOB 对象
return new SerialBlob(imageBytes);
}
public static void main(String[] args) throws Exception {
String schoolFaceBase64 = "iVBORw0KGgoAAAANSUhEUgAAA..."; // 示例Base64字符串
Blob blob = base64ToBlob(schoolFaceBase64);
// 输出 BLOB 的长度
System.out.println("BLOB size = " + blob.length());
}
}
📌 适用场景
-
✅ 上传图片或文件后,封装为 BLOB 后传递给第三方 SDK 或存储类;
-
✅ 单元测试中模拟 Blob 数据;
-
✅ 不依赖数据库就需要处理 BLOB 类型的通用方法;
-
✅ 与一些只接受
java.sql.Blob
接口的工具类/方法兼容。
💡 注意事项
-
SerialBlob
构造函数会复制字节数组,因此对原数组的更改不会影响 BLOB; -
不是所有 JDBC 驱动都能识别
SerialBlob
,仅用于 Java 内存处理或与兼容接口配合使用; -
若最终要存入 Oracle 数据库,请使用
oracle.sql.BLOB
,并通过 JDBC Connection 写入。