Mysql存储java对象实例详解
时间:2020-10-22 22:33:16|栏目:JAVA代码|点击: 次
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();//从流中读取对象
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
栏 目:JAVA代码
下一篇:SpringMVC Restful api接口实现的代码
本文标题:Mysql存储java对象实例详解
本文地址:http://www.codeinn.net/misctech/14673.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




