Mysql存儲(chǔ)二進(jìn)制對(duì)象數(shù)據(jù)問題
Mysql存儲(chǔ)二進(jìn)制對(duì)象數(shù)據(jù)
首先數(shù)據(jù)庫存儲(chǔ)一個(gè)Object對(duì)象
需要在數(shù)據(jù)庫表中定義一個(gè)blob類型的字段

與數(shù)據(jù)庫對(duì)應(yīng)的實(shí)體類

編寫一個(gè)操作二進(jìn)制的工具類
import java.io.*;
/**
* byte[]類型操作類
*/
public class BlobUtil {
/**
* 把object對(duì)象序列化為二進(jìn)制字節(jié)數(shù)組
* @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();
}
/**
* 把二進(jìn)制字節(jié)數(shù)組反序列化為object對(duì)象
* object當(dāng)中的每個(gè)javaBean對(duì)象都必須實(shí)現(xiàn)序列化
* 最外層的類必須生成一個(gè)序列化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;
}
}需要轉(zhuǎn)換為byte[]的對(duì)象必須實(shí)現(xiàn)序列化和生成一個(gè)序列化ID,生成一個(gè)序列化ID是為了解決類當(dāng)中一但有修改,反序列化時(shí)序列化ID就會(huì)對(duì)應(yīng)不上,如下圖:
類中如果有其他類為變量也需要實(shí)現(xiàn)序列化,否則從數(shù)據(jù)庫中取出數(shù)據(jù)然后反序列化成Object對(duì)象的時(shí)候會(huì)直接報(bào)錯(cuò)
對(duì)user的數(shù)據(jù)進(jìn)行操作
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;
}
}調(diào)用二進(jìn)制工具類來轉(zhuǎn)換數(shù)據(jù)然后進(jìn)行存取就可以了。
測(cè)試功能
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("=====對(duì)象轉(zhuǎn)換成blob類型數(shù)據(jù)====="+Arrays.toString(dataValue));
UserVO userVO = (UserVO) BlobUtil.getObject(dataValue);
System.out.println("=====blob類型數(shù)據(jù)轉(zhuǎn)換成對(duì)象====="+ JSONObject.toJSONString(userVO));
}
}打印輸出
=====對(duì)象轉(zhuǎn)換成blob類型數(shù)據(jù)=====[-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類型數(shù)據(jù)轉(zhuǎn)換成對(duì)象====={"userId":"123456","userName":"張三"}
Mysql存儲(chǔ)二進(jìn)制大型對(duì)象類型對(duì)照
MySql MediumBlob——MySql的Bolb四種類型
MySQL中,BLOB是一個(gè)二進(jìn)制大型對(duì)象,是一個(gè)可以存儲(chǔ)大量數(shù)據(jù)的容器,它能容納不同大小的數(shù)據(jù)。
BLOB類型實(shí)際是個(gè)類型系列(TinyBlob、Blob、MediumBlob、LongBlob),除了在存儲(chǔ)的最大信息量上不同外,他們是等同的。

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MYSQL數(shù)據(jù)庫使用UTF-8中文編碼亂碼的解決辦法
這篇文章主要介紹了MYSQL數(shù)據(jù)庫使用UTF-8中文編碼亂碼的解決辦法,需要的朋友可以參考下2015-10-10
MySQL數(shù)據(jù)庫常見字段類型長(zhǎng)度匯總大全
這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫常見字段類型長(zhǎng)度匯總大全的相關(guān)資料,需要的朋友可以參考下2024-05-05
MySQL報(bào)錯(cuò)1118,數(shù)據(jù)類型長(zhǎng)度過長(zhǎng)問題及解決
在使用MySQL過程中,常見的一個(gè)問題是報(bào)錯(cuò)1118,這通常發(fā)生在創(chuàng)建表時(shí),錯(cuò)誤提示為“Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual2024-10-10
MySQL的查詢計(jì)劃中ken_len的值計(jì)算方法
本文首先介紹了MySQL的查詢計(jì)劃中ken_len的含義;然后介紹了key_len的計(jì)算方法;最后通過一個(gè)偽造的例子,來說明如何通過key_len來查看聯(lián)合索引有多少列被使用2017-02-02
淺談MYSQL中樹形結(jié)構(gòu)表3種設(shè)計(jì)優(yōu)劣分析與分享
在開發(fā)中經(jīng)常遇到樹形結(jié)構(gòu)的場(chǎng)景,本文將以部門表為例對(duì)比幾種設(shè)計(jì)的優(yōu)缺點(diǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
mysql允許外網(wǎng)訪問以及修改mysql賬號(hào)密碼實(shí)操方法
這篇文章主要介紹了mysql允許外網(wǎng)訪問以及修改mysql賬號(hào)密碼實(shí)操方法,有需要的朋友們可以參考學(xué)習(xí)下。2019-08-08

