MySQL 建索引时报 Specified key 'idx_t' was too long; max key length is 767 bytes 错误的解决办法~

今天在做 sql 优化时,对之前的表添加个索引,却报出了 Specified key 'idx_t' was too long; max key length is 767 bytes 提示

MySQL 建索引时报 Specified key 'idx_t' was too long; max key length is 767 bytes 错误的解决办法~_第1张图片

后来通过查询资料,发现:

由于 MySQL Innodb 引擎表索引字段长度的限制为 767 字节,因此对于多字节字符集的大字段(或者多字段组合索引),创建索引会出现上面的错误。

以 utf8mb4 字符集 字符串类型字段为例:utf8mb4 是 4 字节字符集,则默认支持的索引字段最大长度是: 767 字节 / 4 字节每字符 = 191 字符,因此在 varchar(255) 或 char(255) 类型字段上创建索引会失败。

MySQL 建索引时报 Specified key 'idx_t' was too long; max key length is 767 bytes 错误的解决办法~_第2张图片

改了一下字段的长度即可~

你可能感兴趣的:(Mysql)