时间:2023-03-15来源:系统城装机大师作者:佚名
需要在数据库表中定义一个blob类型的字段
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
import java.io.*; /** * byte[]类型操作类 */ public class BlobUtil { /** * 把object对象序列化为二进制字节数组 * @param object * @return */ public static byte [] setObject(Object object) { ByteArrayOutputStream baos = null ; ObjectOutputStream out = null ; try { baos = new ByteArrayOutputStream(); out = new ObjectOutputStream(baos); out.writeObject(object); } catch (Exception e) { e.printStackTrace(); } finally { if (out != null ) { try { out.close(); } catch (IOException e) { e.printStackTrace(); } } if (baos != null ) { try { baos.close(); } catch (IOException e) { e.printStackTrace(); } } } return baos.toByteArray(); } /** * 把二进制字节数组反序列化为object对象 * object当中的每个javaBean对象都必须实现序列化 * 最外层的类必须生成一个序列化ID * @param bytes * @return */ public static Object getObject( byte [] bytes) { Object obj = null ; ByteArrayInputStream bais = null ; ObjectInputStream in = null ; try { bais = new ByteArrayInputStream(bytes); in = new ObjectInputStream(bais); obj = in.readObject(); } catch (Exception e) { e.printStackTrace(); } finally { if (in != null ) { try { in.close(); } catch (IOException e) { e.printStackTrace(); } } if (bais != null ) { try { bais.close(); } catch (IOException e) { e.printStackTrace(); } } } return obj; } } |
需要转换为byte[]的对象必须实现序列化和生成一个序列化ID,生成一个序列化ID是为了解决类当中一但有修改,反序列化时序列化ID就会对应不上,如下图:
类中如果有其他类为变量也需要实现序列化,否则从数据库中取出数据然后反序列化成Object对象的时候会直接报错
对user的数据进行操作
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
import java.io.Serializable; /** * @author * @description * @date */ public class UserVO implements Serializable { private static final long serialVersionUID = 1L; private String userId; private String userName; private String password; public String getUserId() { return userId; } public void setUserId(String userId) { this .userId = userId; } public String getUserName() { return userName; } public void setUserName(String userName) { this .userName = userName; } public String getPassword() { return password; } public void setPassword(String password) { this .password = password; } } |
调用二进制工具类来转换数据然后进行存取就可以了。
测试功能
1 2 3 4 5 6 7 8 9 10 11 12 |
public class TestMain { public static void main(String[] args) { UserVO user = new UserVO(); user.setUserId( "123456" ); user.setUserName( "张三" ); byte [] dataValue = BlobUtil.setObject(user); System.out.println( "=====对象转换成blob类型数据=====" +Arrays.toString(dataValue)); UserVO userVO = (UserVO) BlobUtil.getObject(dataValue); System.out.println( "=====blob类型数据转换成对象=====" + JSONObject.toJSONString(userVO)); } } |
打印输出
=====对象转换成blob类型数据=====[-84, -19, 0, 5, 115, 114, 0, 53, 99, 111, 109, 46, 100, 111, 108, 112, 104, 105, 110, 46, 109, 111, 100, 117, 108, 101, 115, 46, 116, 109, 115, 46, 100, 111, 109, 97, 105, 110, 46, 99, 117, 115, 116, 111, 109, 101, 114, 115, 101, 114, 118, 105, 99, 101, 46, 85, 115, 101, 114, 86, 79, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 3, 76, 0, 8, 112, 97, 115, 115, 119, 111, 114, 100, 116, 0, 18, 76, 106, 97, 118, 97, 47, 108, 97, 110, 103, 47, 83, 116, 114, 105, 110, 103, 59, 76, 0, 6, 117, 115, 101, 114, 73, 100, 113, 0, 126, 0, 1, 76, 0, 8, 117, 115, 101, 114, 78, 97, 109, 101, 113, 0, 126, 0, 1, 120, 112, 112, 116, 0, 6, 49, 50, 51, 52, 53, 54, 116, 0, 6, -27, -68, -96, -28, -72, -119]
=====blob类型数据转换成对象====={"userId":"123456","userName":"张三"}
MySQL中,BLOB是一个二进制大型对象,是一个可以存储大量数据的容器,它能容纳不同大小的数据。
BLOB类型实际是个类型系列(TinyBlob、Blob、MediumBlob、LongBlob),除了在存储的最大信息量上不同外,他们是等同的。
2023-10-30
windows上的mysql服务突然消失提示10061 Unkonwn error问题及解决方案2023-10-30
MySQL非常重要的日志bin log详解2023-10-30
详解MySQL事务日志redo log一、单表查询 1、排序 2、聚合函数 3、分组 4、limit 二、SQL约束 1、主键约束 2、非空约束 3、唯一约束 4、外键约束 5、默认值 三、多表查询 1、内连接 1)隐式内连接: 2)显式内连接: 2、外连接 1)左外连接 2)右外连接 四...
2023-10-30
Mysql删除表重复数据 表里存在唯一主键 没有主键时删除重复数据 Mysql删除表中重复数据并保留一条 准备一张表 用的是mysql8 大家自行更改 创建表并添加四条相同的数据...
2023-10-30