MySQL中blob 与 text

 

BLOB是一个二进制大对象,能够容纳可变数量的数据。有4种BLOB类型:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB。它们只是可容纳值的最大长度不一样。mysql

 

有4种TEXT类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。这些对应4种BLOB类型,有相同的最大长度和存储需求。sql

 

 

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列分配存储引擎

相关文章
相关标签/搜索