服务器之家

服务器之家 > 正文

Mysql存储java对象实例详解

时间:2020-07-05 13:47     来源/作者:

Mysql存储java对象

MySQL  设置字段为 blob

保存对象,先将对象序列化为byte[]  使用 setObject(byte[] bytes)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
ByteArrayOutputStream baos = new ByteArrayOutputStream();
    ObjectOutputStream out = null;
    try {
      out = new ObjectOutputStream(baos);
      out.writeObject(java实例对象);   
    } catch (IOException e) {
      logger.error("msg2Bytes error!", e);
    }finally{
      try {
        out.close();
      } catch (IOException e) {
        logger.error("msg2Bytes error!", e);
      }
    }
     
    return baos.toByteArray();

获取对象 使用getBytes(),将获取的byte[]反序列化为Java 对象

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
ByteArrayInputStream bais;
    ObjectInputStream in = null;
    try{
      bais = new ByteArrayInputStream(bytes);
      in = new ObjectInputStream(bais);
 
      return (java类)in.readObject();
    }finally{
      if(in != null){
        try {
          in.close();
        } catch (IOException e) {
          logger.error("bytes2Msg error!", e);
        }
      }
    }

网上的其他方式会有各类问题,请慎用。

包括:

1.设置url参数 autoDeserialize=true
2.setObject(java实例对象)        查询

ObjectInputStream oips = new ObjectInputStream(rs.getBinaryStream(1)); 
ArrayList<String> obb = (java类)oips.readObject();//从流中读取对象 

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享 2020-04-07
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意 2019-07-07
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
返回顶部