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();//从流中读取对象
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!