源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Mysql存储java对象实例详解

  • 时间:2020-12-15 15:48 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Mysql存储java对象实例详解
[b]Mysql存储java对象[/b] MySQL  设置字段为 blob 保存对象,先将对象序列化为byte[]  使用 setObject(byte[] bytes)
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 对象
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();//从流中读取对象  感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部