Mysql存储java对象
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();//从流中读取对象
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索Mysql存储java对象
mysql多实例详解、mysql实例详解、sql存储过程实例详解、mysql存储过程实例、mysql存储过程详解,以便于您获取更多的相关知识。
时间: 2025-01-03 08:02:09