压缩存储在mysql中的数据

Posted

技术标签:

【中文标题】压缩存储在mysql中的数据【英文标题】:Compressing data stored in mysql 【发布时间】:2012-02-02 13:53:44 【问题描述】:

我们将完整的 html 页面存储在我们的表中名为“conteny”的字段中。现在这个表就像一个档案,我们很少使用它。 'content' 字段现在是 'longtext' 类型,我想知道哪种方法是我们可以压缩和保留此表数据的最佳方式,因为它占用了许多 gb 的空间。

我尝试在 php 的 content 字段上简单地使用 gzcompress 函数,但这不起作用。例如

 $content = gzcompress($content,9);

也试过了,但还是不行:

update posts_content set content = COMPRESS(content)

有什么想法最好的方法和方法吗?

Is mysql automatically compressing the database? 的另一个问题是关于 INNODB,但我们使用 MISAM 并且可能会迁移到 INNODB 作为最后的手段。

谢谢你

【问题讨论】:

看看这个问题-***.com/questions/8228950/… 如果字段类型是 TEXT,那么压缩的二进制数据可能会被字符集转换损坏。使用 BLOB 类型存储原始二进制数据 - 它们不受字符集转换的影响。 【参考方案1】:

使用压缩时,结果是二进制而不是文本。您不应该尝试将结果存储在文本列中。 BLOB 列应该与 gzcompress 方法一起使用。

【讨论】:

以上是关于压缩存储在mysql中的数据的主要内容,如果未能解决你的问题,请参考以下文章

MySQL之MyISAM存储引擎压缩表

压缩保存在 Google 云存储中的文件

MySql存储引擎+表解压缩机制+索引+查询缓存机制+慢查询日志

如何将包含 30 多个压缩文件的文件夹存储到 r 中的变量中

一文彻底搞懂Hive的数据存储与压缩

数据结构-特殊矩阵的压缩存储