Byte数组保存到MySQL后长度增加的问题
创始人
2025-01-12 22:36:13
0

这是因为MySQL对于BLOB类型的数据默认使用了UTF-8编码,而UTF-8编码是一种变长编码。因此,解决此问题的方法是在将Byte数组写入MySQL前,将其转换为字符集为latin1的字符串,这样可以保证长度不再发生变化。具体代码实现如下:

// byte数组转为latin1编码的字符串
public static String latin1ByteArrayToString(byte[] bytes) {
    Charset latin1Charset = Charset.forName("ISO-8859-1");
    CharBuffer buffer = latin1Charset.decode(ByteBuffer.wrap(bytes));
    return buffer.toString();
}

// latin1编码的字符串转为byte数组
public static byte[] latin1StringToByteArray(String str) {
    Charset latin1Charset = Charset.forName("ISO-8859-1");
    ByteBuffer buffer = latin1Charset.encode(CharBuffer.wrap(str));
    byte[] bytes = new byte[buffer.limit()];
    buffer.get(bytes);
    return bytes;
}

// 将byte数组写入MySQL
public static void writeByteArrayToMySQL(byte[] bytes) {
    try {
        String latin1Str = latin1ByteArrayToString(bytes);
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/mydb", "user", "password");
        PreparedStatement ps = conn.prepareStatement("INSERT INTO mytable (mycolumn) VALUES (?)");
        ps.setString(1, latin1Str);
        ps.executeUpdate();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

// 从MySQL读取byte数组
public static byte[] readByteArrayFromMySQL() {
    try {
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/mydb", "user", "password");
        PreparedStatement ps = conn.prepareStatement("SELECT mycolumn FROM mytable WHERE id = ?");
        ps.setInt(1, 1);
        ResultSet rs = ps.executeQuery();
        if (rs.next()) {
            String latin1Str = rs.getString("mycolumn");
            return latin1StringToByteArray(latin1Str);
        }
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return null;
}

相关内容

热门资讯

WePoKe外 挂!wepok... wepOke赢率提升策略‌;WePoKe外 挂!wepoke软件透明挂演示,wepOke本来真的有挂...
wpk俱乐部!德州wpk德州真... wpk俱乐部!德州wpk德州真的,wPK都是真的有挂,详细教程,(有挂辅助)所有人都在同一条线上,像...
德州之星插件!德扑ai人工智能... 德州之星插件!德扑ai人工智能,智星德州都是存在有挂(详细猫腻教程)1、每个玩家都可以进行使用,快速...
wpk有外 挂!线上wpk德州... wpk有外 挂!线上wpk德州ai机器人,wpK都是真的有挂,详细教程,(有挂解说)wpk辅助器中分...
wepoke透明挂黑科技!we... wepoke透明挂黑科技!wepoke游戏数据有说法(透明挂)wepokE(一贯真的有挂);支持多人...
德州ai机器人!德扑之星内部,... 德州ai机器人!德扑之星内部,德州扑克竟然是真的有挂(详细辅助挂教程)(1)德州ai机器人!德扑之星...
wepokeai机器人!wep... wepokeai机器人!wepoke是是有辅助,WEpoke好像真的有挂,攻略方法(有挂揭秘)1、让...
wpk真的有外 挂!WpK果然... wpk真的有外 挂!WpK果然真的有挂,wPk其实真的有挂,2025新版总结(有挂揭秘)1、很好的工...
德扑数据软件!德州ai人工智能... 您好,德州ai人工智能这款游戏可以开挂的,确实是有挂的,需要了解加微【757446909】很多玩家在...
wepoke透明黑科技!wop... wepoke透明黑科技!wopoker辅助v3.0(透明挂)wEpOke(的确真的有挂);原来确实真...