mysql的BLOB类型

  1. 1、BLOB类型
    1、BLOB类型介绍
  2. (1)BLOB类型的含义
    BLOB (binary large object),用来存储二进制大对象的字段类型。
    BLOB往往是一个大文件,典型的BLOB是一张图片、一个声音或一个视频文件,由于它们的尺寸,必须使用特殊的方式来处理(例如:上传、下载或者存放到一个数据库)。
    处理BLOB的主要思想就是让文件处理器(如数据库管理器)不去理会文件是什么,而是关心如何去处理它。但也有专家强调,这种处理大数据对象的方法是把双刃剑,它有可能引发一些问题,如存储的二进制文件过大,会使数据库的性能下降。

    (2)BLOB类型系列
    MySQL中,BLOB是个类型系列,共包括四种BLOB类型:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储文件的最大尺寸不同。

    字段类型 最大长度(字节)   存储需求
    TinyBlob 255   值的长度加上用于记录长度的1个字节(8位)
    Blob 65K值的长度加上用于记录长度的2个字节(16位)
    MediumBlob 16M值的长度加上用于记录长度的3个字节(24位)
    LongBlob 4G   值的长度加上用于记录长度的4个字节(32位)

    (3)MySQL中的BLOB类型大小限制
    MySQL 对LongBlob类型字段的最大存储容量默认限定为1M,即如果你要存储大于1M的二进制大对象,需要修改MySQL数据库的大小,使其能支持更大的二进制容量。
    可在 etc/my.cnf文件中增加设置如下(linux):
    [mysqld] 
    max_allowed_packet=16M 

    2、BLOB类型与TEXT类型差别
    (1)TEXT类型
    有4种TEXT类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。这些对应4种BLOB类型,有相同的最大长度和存储需求。  
    BLOB 列被视为二进制字符串(字节字符串)。TEXT列被视为非二进制字符串(字符字符串)。BLOB列没有字符集,并且排序和比较基于列值字节的数值值。TEXT列有一个字符集,并且根据字符集的 校对规则对值进行排序和比较。  
    在TEXT或BLOB列的存储或检索过程中,不存在大小写转换。  

  3. (2)最大长度
    当未运行在严格模式时,如果你为BLOB或TEXT列分配一个超过该列类型的最大长度的值值,值被截取以保证适合。如果截掉的字符不是空格,将会产生一条警告。使用严格SQL模式,会产生错误,并且值将被拒绝而不是截取并给出警告。  
    在大多数方面,可以将BLOB列视为能够足够大的VARBINARY列。同样,可以将TEXT列视为VARCHAR列。BLOB和TEXT在以下几个方面不同于VARBINARY和VARCHAR:  
    当保存或检索BLOB和TEXT列的值时不删除尾部空格。(这与VARBINARY和VARCHAR列相同)。  
    请注意比较时将用空格对TEXT进行扩充以适合比较的对象,正如CHAR和VARCHAR。  

  4. (3)索引  
    对于BLOB和TEXT列的索引,必须指定索引前缀的长度。对于CHAR和VARCHAR,前缀长度是可选的。

  5. (4)默认值
    BLOB和TEXT列不能有 默认值。  
    LONG和LONG VARCHAR对应MEDIUMTEXT数据类型。这是为了保证兼容性。如果TEXT列类型使用BINARY属性,将为列分配列字符集的二元 校对规则。  
    MySQL连接程序/ODBC将BLOB值定义为LONGVARBINARY,将TEXT值定义为LONGVARCHAR。 

  6. (5)排序 
    由于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变量的值更改消息缓存区的大小,但必须同时修改服务器和客户端程序。
  7. 例如,可以使用 mysql和mysqldump来更改客户端的max_allowed_packet值。  
    每个BLOB或TEXT值分别由内部分配的对象表示。这与其它列类型形成对比,后者是当打开表时为每1列分配存储引擎。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值