将一个序列化的对象存放到数据库的方法

本文介绍了如何将序列化的Java对象转换为字节数据并存储到数据库中,以及如何使用getBlob方法从数据库中读取并还原这些对象。通过这种方法,可以实现对象的持久化存储。
摘要由CSDN通过智能技术生成

将序列化的对象转成字节数据,将字节数据存放到数据库;

从数据库取出来是以getBlod的方法得到字节数据

public class TypeChangeTool {

private static final String TAG = TypeChangeTool.class.getSimpleName();
public static byte[] toByte(Object object) {
Log.d(TAG, "TypeChangeTool toByte()");
byte[] data = null;
if(object != null){
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
try {
ObjectOutputStream objectOutputStream = new ObjectOutputStream(byteArrayOutputStream);
objectOutputStream.writeObject(object);
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java的序列化是指将一个Java对象转换成字节序列的过程,以便可以将其存储到文件、数据库或在网络上传输。只有实现了Serializable或Externalizable接口的类的对象才能被序列化,否则会抛出异常。 Java的反序列化则是将字节序列重新转换成Java对象的过程。通过反序列化,可以从文件、数据库或网络中读取字节序列,并将其转换回原始的Java对象。 Java的序列化和反序列化有以下几个好处: 1. 数据持久化:通过序列化,可以将对象永久地保存到硬盘上,通常存放在文件中。这样可以实现数据的长期存储和读取。 2. 远程通信:通过序列化和反序列化,可以在网络上传送对象的字节序列,实现远程通信。这在分布式系统和客户端-服务器应用中非常有用。 在Java的序列化机制中,版本一致性非常重要。当进行反序列化时,JVM会通过比较传来的字节流中的serialVersionUID和本地相应对象的serialVersionUID来验证版本一致性。如果两者相同,就认为是一致的,可以进行反序列化。否则,就会出现序列化版本不一致的异常。 需要注意的是,如果实现了java.io.Serializable接口的类没有显式地定义一个名为serialVersionUID的变量,Java序列化机制会根据编译的class自动生成一个serialVersionUID用于序列化版本比较。但是只有同一次编译生成的class才会生成相同的serialVersionUID。因此,在进行序列化和反序列化时,确保对象的类定义和使用的类定义是一致的非常重要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值