共计 2307 个字符,预计需要花费 6 分钟才能阅读完成。
自动写代码机器人,免费开通
丸趣 TV 小编给大家分享一下 mysql 中 blob 是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
BLOB (binary large object),二进制大对象,是一个可以存储二进制文件的容器。在计算机中,BLOB 常常是数据库中用来存储二进制文件的字段类型。BLOB 是一
个大文件,典型的 BLOB 是一张图片或一个声音文件,由于它们的尺寸,必须使用特殊的方式来处理(例如:上传、下载或者存放到一个数据库)。根据 Eric Raymond 的
说法,处理 BLOB 的主要思想就是让文件处理器(如数据库管理器)不去理会文件是什么,而是关心如何去处理它。但也有专家强调,这种处理大数据对象的方法是把双
刃剑,它有可能引发一些问题,如存储的二进制文件过大,会使数据库的性能下降。在数据库中存放体积较大的多媒体对象就是应用程序处理 BLOB 的典型例子。
mysql BLOB 类型
MySQL 中,BLOB 是个类型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储文件的最大大小上不同。
MySQL 的四种 BLOB 类型
类型 大小(单位:字节)
TinyBlob 最大 255
Blob 最大 65K
MediumBlob 最大 16M
LongBlob 最大 4G
linux 修改 etc/my.cnf
[mysqld]
max_allowed_packet = 16M // 不同于 [mysqldump] 下的 max_allowed_packet
BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们只是可容纳值的最大长度不同。
有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。这些对应 4 种 BLOB 类型,有相同的最大长度和存储需求。
BLOB 列被视为二进制字符串(字节字符串)。TEXT 列被视为非二进制字符串(字符字符串)。BLOB 列没有字符集,并且排序和比较基于列值字节的数值值。TEXT 列有一个字符集,并且根据字符集的 校对规则对值进行排序和比较。
在 TEXT 或 BLOB 列的存储或检索过程中,不存在大小写转换。
当未运行在严格模式时,如果你为 BLOB 或 TEXT 列分配一个超过该列类型的最大长度的值值,值被截取以保证适合。如果截掉的字符不是空格,将会产生一条警告。使用严格 SQL 模式,会产生错误,并且值将被拒绝而不是截取并给出警告。
在大多数方面,可以将 BLOB 列视为能够足够大的 VARBINARY 列。同样,可以将 TEXT 列视为 VARCHAR 列。BLOB 和 TEXT 在以下几个方面不同于 VARBINARY 和 VARCHAR:
· 当保存或检索 BLOB 和 TEXT 列的值时不删除尾部空格。(这与 VARBINARY 和 VARCHAR 列相同)。
请注意比较时将用空格对 TEXT 进行扩充以适合比较的对象,正如 CHAR 和 VARCHAR。
· 对于 BLOB 和 TEXT 列的索引,必须指定索引前缀的长度。对于 CHAR 和 VARCHAR,前缀长度是可选的。
· BLOB 和 TEXT 列不能有 默认值。
LONG 和 LONG VARCHAR 对应 MEDIUMTEXT 数据类型。这是为了保证兼容性。如果 TEXT 列类型使用 BINARY 属性,将为列分配列字符集的二元 校对规则。
MySQL 连接程序 /ODBC 将 BLOB 值定义为 LONGVARBINARY,将 TEXT 值定义为 LONGVARCHAR。
由于 BLOB 和 TEXT 值可能会非常长,使用它们时可能遇到一些约束:
· 当排序时只使用该列的前 max_sort_length 个字节。max_sort_length 的 默认值是 1024;该值可以在启动 mysqld 服务器时使用 –max_sort_length 选项进行更改。
运行时增加 max_sort_length 的值可以在排序或组合时使更多的字节有意义。任何客户端可以更改其会话 max_sort_length 变量的值:
mysql SET max_sort_length = 2000;
mysql SELECT id, comment FROM tbl_name
– ORDER BY comment;
当你想要使超过 max_sort_length 的字节有意义,对含长值的 BLOB 或 TEXT 列使用 GROUP BY 或 ORDER BY 的另一种方式是将列值转换为固定长度的对象。标准方法是使用 SUBSTRING 函数。例如,下面的语句对 comment 列的 2000 个字节进行排序:
mysql SELECT id, SUBSTRING(comment,1,2000) FROM tbl_name
– ORDER BY SUBSTRING(comment,1,2000);
· BLOB 或 TEXT 对象的最大大小由其类型确定,但在客户端和服务器之间实际可以传递的最大值由可用内存数量和通信缓存区大小确定。你可以通过更改 max_allowed_packet 变量的值更改消息缓存区的大小,但必须同时修改服务器和客户端程序。例如,可以使用 mysql 和 mysqldump 来更改客户端的 max_allowed_packet 值。
每个 BLOB 或 TEXT 值分别由内部分配的对象表示。这与其它列类型形成对比,后者是当打开表时为每 1 列分配存储引擎。
以上是“mysql 中 blob 是什么”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!
向 AI 问一下细节