热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

在Java中实现MySQL的Compress()和Uncompress()算法

在Java中实现MySQL的Compress()和Uncompress()算法MySQLCOMPRESS()函数用于压缩字符串。COMPRESS()函数返回的值是二进制字符串。CO

在Java中实现MySQL的Compress()和Uncompress()算法

MySQL COMPRESS()函数用于压缩字符串。 COMPRESS()函数返回的值是二进制字符串。

COMPRESS()函数将非空字符串存储为未压缩字符串的four-byte长度,然后是压缩字符串。如果字符串以空格结尾,则将“.”字符添加到字符串。另外,应注意,空字符串存储为空字符串。 COMPRESS()函数接受一个参数,该参数是要压缩的字符串。

在mysql存储的某个字段过长,可以考虑使用COMPRESS() 和uncompress(),但是会占用DB端的cpu消耗,可以考虑将这部分压缩放着服务端。

下面给出了在java代码中实现compress() 和 uncopresss()逻辑


/**
* 压缩工具类
*
* @author 行舟QaQ
*/
@Slf4j
public class GZIPUtils {
private GZIPUtils() {
}
/**
* 使用zlib压缩
*
* @param data
* @return
*/
public static byte[] compressZLib(byte[] data) {
Deflater deflater = new Deflater();
deflater.setInput(data);
deflater.finish();
ByteArrayOutputStream outputStream = new ByteArrayOutputStream(data.length);
byte[] buffer = new byte[1024];
while (!deflater.finished()) {
int count = deflater.deflate(buffer);
outputStream.write(buffer, 0, count);
}
try {
outputStream.close();
} catch (IOException e) {
log.error("compressZLib outputStream close error,data-->{}, e-->{}",
JSONP.toJson(data),e);
}
return outputStream.toByteArray();
}
/**
* mysql压缩加入长度
*
* @param input
* @return
*/
public static byte[] compressToMysql(String input) {
if (StringUtils.isEmpty(input)) {
return new byte[]{};
}
byte[] lengthBytes = lengthToBinary(input.length());
byte[] compressedBytes = compressZLib(input.getBytes(StandardCharsets.UTF_8));
return binaryConcat(lengthBytes, compressedBytes);
}
/**
* 长度转二进制,并且最少为4
*
* @param length
* @return
*/
private static byte[] lengthToBinary(int length) {
byte[] bytes = binaryReverse((String.valueOf(length).getBytes(StandardCharsets.UTF_8)));
byte[] newByte = new byte[4];
byte[] bytesForStorage = binaryConcat(bytes, newByte);
byte[] res = new byte[4];
for (int i = 0; i res[i] = bytesForStorage[i];
}
// 返回前4位
return res;
}
/**
* 合并数据
*
* @param bytes
* @param newByte
* @return
*/
private static byte[] binaryConcat(byte[] bytes, byte[] newByte) {
int length = bytes.length + newByte.length;
// Make sure the resultant value is at least 4-bytes.
ByteArrayOutputStream outputStream = new ByteArrayOutputStream(length);
try {
outputStream.write(bytes);
outputStream.write(newByte);
} catch (IOException e) {
log.error("binaryConcat outputStream error,bytes -- > {},newByte-->{}, e-->{}",
JSONP.toJson(bytes), JSONP.toJson(newByte),e);
throw new ServiceException();
}
return outputStream.toByteArray();
}
/**
* 反转数组
*
* @param bytes
* @return
*/
private static byte[] binaryReverse(byte[] bytes) {
int length = bytes.length;
byte[] res = new byte[length];
for (int i = 0; i res[length - i - 1] = bytes[i];
}
return res;
}
/**
* zlib解压
*
* @param data
* @return
*/
public static String decompressZLib(byte[] data) {
Inflater inflater = new Inflater();
inflater.setInput(data);
ByteArrayOutputStream outputStream = new ByteArrayOutputStream(data.length);
byte[] buffer = new byte[1024];
try {
while (!inflater.finished()) {
int count = inflater.inflate(buffer);
outputStream.write(buffer, 0, count);
}
outputStream.close();
} catch (Exception e) {
log.error("decompressZLib error,buffer -- > {},data-->{}, e-->{}",
JSONP.toJson(buffer), JSONP.toJson(data),e);
}
return outputStream.toString();
}
/**
* 解压入口
*
* @param input
* @return
*/
public static String uncompressMysql(byte[] input) {
if (input == null || input.length == 0) {
return "";
}
String s = decompressZLib(Arrays.copyOfRange(input, 4, input.length));
return s;
}
}


推荐阅读
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • Android工程师面试准备及设计模式使用场景
    本文介绍了Android工程师面试准备的经验,包括面试流程和重点准备内容。同时,还介绍了建造者模式的使用场景,以及在Android开发中的具体应用。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 流数据流和IO流的使用及应用
    本文介绍了流数据流和IO流的基本概念和用法,包括输入流、输出流、字节流、字符流、缓冲区等。同时还介绍了异常处理和常用的流类,如FileReader、FileWriter、FileInputStream、FileOutputStream、OutputStreamWriter、InputStreamReader、BufferedReader、BufferedWriter等。此外,还介绍了系统流和标准流的使用。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • 本文介绍了Android中的assets目录和raw目录的共同点和区别,包括获取资源的方法、目录结构的限制以及列出资源的能力。同时,还解释了raw目录中资源文件生成的ID,并说明了这些目录的使用方法。 ... [详细]
  • 上图是InnoDB存储引擎的结构。1、缓冲池InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。因此可以看作是基于磁盘的数据库系统。在数据库系统中,由于CPU速度 ... [详细]
  • 本文讨论了如何使用GStreamer来删除H264格式视频文件中的中间部分,而不需要进行重编码。作者提出了使用gst_element_seek(...)函数来实现这个目标的思路,并提到遇到了一个解决不了的BUG。文章还列举了8个解决方案,希望能够得到更好的思路。 ... [详细]
  • 本文整理了Java中java.lang.NoSuchMethodError.getMessage()方法的一些代码示例,展示了NoSuchMethodErr ... [详细]
  • 使用freemaker生成Java代码的步骤及示例代码
    本文介绍了使用freemaker这个jar包生成Java代码的步骤,通过提前编辑好的模板,可以避免写重复代码。首先需要在springboot的pom.xml文件中加入freemaker的依赖包。然后编写模板,定义要生成的Java类的属性和方法。最后编写生成代码的类,通过加载模板文件和数据模型,生成Java代码文件。本文提供了示例代码,并展示了文件目录结构。 ... [详细]
  • Question该提问来源于开源项目:react-native-device-info/react-native-device-info ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
author-avatar
手机用户2602937685
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有