修改Mysql索引长度限制 解决767 byte限制
报错:Specified key was too long; max key length is 767 bytes
原因:msyql5.6及以前版本, 默认索引最大长度767bytes,若使用utf8mb4格式编码(utf8字符占用3字节,utf8mb4字符占用4字节), 则单个字段长度不能超过191, 5.7及之后版本, 限制放开到3072 bytes。
解决方案:
一、将数据库版本升级到5.7版本或以上;
二、修改相关配置,增加操作以解决,解决方案如下:
1、在my.ini中修改配置:
innodb_large_prefix = ON
innodb_file_format = Barracuda
innodb_file_per_table = ON
2、在create中添加row_format=dynamic
create table sql_test(
id int ,
name VARCHAR(200),
server_id VARCHAR(30),
id_num1 VARCHAR(30),
id_num2 VARCHAR(30),
link VARCHAR(500),
PRIMARY KEY (id),
KEY sql_test_name (name))
engine=innodb row_format=dynamic;
最后更新于 2022-09-07 10:53:10 并被添加「」标签,已有 4941 位童鞋阅读过。
本站使用「署名 4.0 国际」创作共享协议,可自由转载、引用,但需署名作者且注明文章出处