跳到主要内容
版本:V1.0.0

TEXT 类型

TEXT 类型用于存储所有类型的文本数据。

文本类型包括四种,分别是 TINYTEXTTEXTMEDIUMTEXTLONGTEXT。它们对应于四种 BLOB 类型,并且具有相同的最大长度和存储要求。

TEXT 值被视为非二进制字符串。它们具有二进制以外的字符集,并且根据字符集的排序规则对值进行排序和比较。

在未启用严格的 SQL 模式时,如果为 TEXT 列分配的值超过该列的最大长度,则该值超出长度的部分将被截断并生成告警。在使用严格的 SQL 模式时,如果截断的是非空格字符,会发生错误(而不是告警)并禁止插入值。无论 SQL 模式如何,截断插入到 TEXT 列的值中多余的尾部空格时,总是会生成告警。

TINYTEXT

TINYTEXT 是最大长度为 255 个字节的 TEXT 类型。

TINYTEXT 语法如下:

TINYTEXT [CHARACTER SET charset_name] [COLLATE collation_name]

CHARACTER SET 用于指定字符集。如果需要,可以使用 COLLATE 属性以及其他属性指定字符集的排序规则。如果指定 CHARACTER SET 的二进制属性,则会导致将列创建为相应的二进制字符串数据类型,TEXT 会变为 BLOB

TEXT

TEXT 列的最大长度为 65,535 个字节。

可以为 TEXT 类型指定一个可选的长度 M。语法如下:

TEXT[(M)] [CHARACTER SET charset_name] [COLLATE collation_name]

CHARACTER SET 用于指定字符集。如果需要,可以使用 COLLATE 属性以及其他属性指定字符集的排序规则。如果指定 CHARACTER SET 的二进制属性,则会导致将列创建为相应的二进制字符串数据类型,TEXT 会变为 BLOB

MEDIUMTEXT

MEDIUMTEXT 是最大长度为 16,777,215 个字节的 TEXT 类型。

MEDIUMTEXT 语法如下:

MEDIUMTEXT [CHARACTER SET charset_name] [COLLATE collation_name]

CHARACTER SET 用于指定字符集。如果需要,可以使用 COLLATE 属性以及任何其他属性指定字符集的排序规则。如果指定 CHARACTER SET 的二进制属性会导致将列创建为相应的二进制字符串数据类型,TEXT 会变为 BLOB

另外,seekdb 还支持扩展类型 LONG,但是推荐使用 MEDIUMTEXT

LONGTEXT

LONGTEXT 是最大长度为 536870910 字节的 TEXT 类型。LONGTEXT 列的有效最大长度还取决于客户端/服务器协议中配置的最大数据包大小和可用内存。

LONGTEXT 语法如下:

LONGTEXT [CHARACTER SET charset_name] [COLLATE collation_name]

CHARACTER SET 用于指定字符集。如果需要,可以使用 COLLATE 属性以及其他属性指定字符集的排序规则。如果指定 CHARACTER SET 的二进制属性,则会导致将列创建为相应的二进制字符串数据类型,TEXT 会变为 BLOB