跳到主要内容

BINARY 和 VARBINARY

BINARYVARBINARY 类型与 CHARVARCHAR 相似,不同之处在于它们存储二进制数据而不是字符串。

BINARYVARBINARY 使用二进制字符集和二进制排序规则。

BINARY

BINARY 类型与 CHAR 类型相似,但其存储二进制字节串。语法如下:

BINARY[(M)]

可选长度参数 M 表示以字节为单位的列长度。如果省略,则取 M 的默认值 1。

BINARY 的最大长度与 CHAR 相同,但长度以字节为单位。在未启用严格 SQL 模式时,如果为 BINARY 列分配的值超过该列的最大长度,则该值超出长度的部分将被截断并生成告警。

存储 BINARY 值时,会用 0x00(零字节)右补位到指定长度,如果插入的数据以 0x00 结尾,也会一同保留,不会删除任何尾部填充字节,以免影响检索效果。在字节比较中,包括 ORDER BYDISTINCT 操作,0x00 和空格是不同的,0x00 排序在空格之前。

VARBINARY

VARBINARY 类型与 VARCHAR 类型相似,但其存储二进制字节串。语法如下:

VARBINARY(M)

M 表示以字节为单位的最大列长度。

VARBINARY 的最大长度与 VARCHAR 相同,但长度以字节为单位。在未启用严格 SQL 模式时,如果为 VARBINARY 列分配的值超过该列的最大长度,则该值超出长度的部分将被截断并生成告警。

对于 VARBINARY,插入数据时不需要填充,不会删除任何尾部填充字节。在字节比较中,包括 ORDER BYDISTINCT 操作,0x00 和空格是不同的,0x00 排序在空格之前。