gpt4 book ai didi

mysql - 在 blob 中存储数据与存储指向文件的指针之间有什么区别?

转载 作者:IT老高 更新时间:2023-10-28 23:52:28 24 4
gpt4 key购买 nike

我对 MySQL 中的 blob 数据类型有疑问。

我读到数据类型可以用来存储文件。我还读到另一种方法是将文件存储在磁盘上,并包含一个指向它在数据库中的位置的指针(通过 varchar 列)。

但我有点困惑,因为我读到 blob 字段没有存储在行中,需要单独查找才能检索其内容。那么这与在文件系统上存储指向文件的指针有什么不同吗?

最佳答案

I read that the data type can be used to store files.

根据MySQL manual在 Blob 上的页面中,BLOB 是一个二进制大对象,可以容纳可变数量的数据。

由于它是一种特定于存储二进制数据的数据类型,因此通常使用它来存储二进制格式的文件,在 Web 应用程序中存储图像文件是一种非常常见的用途。

对于 Web 应用程序,这意味着您首先需要将文件转换为二进制格式,然后将其存储,并且每次需要检索文件时,您都需要执行将它们转换回原始文件的相反过程格式。

除此之外,在您的数据库中存储大量数据可能会减慢它的速度。特别是在不仅仅用于托管数据库的系统中。

I also read that an alternative is to store the file on disk and include a pointer to its location in the database

考虑到上述所有因素,Web 应用程序的一个常见做法是将文件存储在 MySQL 以外的其他位置,然后简单地将其路径存储在数据库中。这种方法可以在处理大量数据时加快您的数据库。

But I'm a little confused because I've read that blob fields are not stored in-row and require a separate look-up to retrieve its contents.

事实上,这取决于您使用的存储引擎,因为每个引擎都以不同的方式处理和存储数据。对于适用于关系数据库的 InnoDB 引擎,您可能需要从 MySQL Performance blog 阅读这篇文章关于 blob 如何存储在 MySQL 中。

但抽象地说,在 MySQL 5 及更高版本上,blob 存储如下:

Innodb stores either whole blob on the row page or only 20 bytes BLOB pointer giving preference to smaller columns to be stored on the page, which is reasonable as you can store more of them.

所以您现在可能认为正确的方法是将它们存储为单独的文件,但是使用 blob 存储数据有一些优点,第一个(在我看来)是备份。我管理着一台小型服务器,我不得不创建另一个子例程,只是为了将作为路径存储的文件复制到另一个存储磁盘(我们买不起像样的磁带备份系统)。如果我将应用程序设计为使用 blob,那么一个简单的 mysqldump 将是我备份整个数据库所需的一切。

为备份存储 blob 的优势在 this post 上有更好的讨论。回答的人和我有类似的问题。

另一个优点是安全性和易于管理权限和访问。 MySQL 服务器中的所有数据都受密码保护,您可以轻松地为用户管理权限,了解谁可以访问什么,谁不可以访问。

在依赖 MySQL 权限系统进行身份验证和使用的应用程序中。这肯定是一个优点,因为对于入侵者来说,从您的磁盘或没有访问权限的用户检索图像(或压缩文件等二进制文件)会有点困难。

所以我会这么说

如果您要管理 MySQL 和其中的所有数据,并且必须定期备份或打算更改甚至考虑将来更改操作系统,并且拥有不错的硬件并针对它优化了 MySQL,请选择 BLOB .

如果您不会管理您的 MySQL(例如在网络主机中)并且不打算更改操作系统或进行备份,请坚持使用 varchar 列指向到您的文件中。

我希望它有所帮助。干杯

关于mysql - 在 blob 中存储数据与存储指向文件的指针之间有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13435187/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com