修改Mysql索引长度限制解决767?byte限制问题 |
报错
原因msyql5.6及以前版本, 默认索引最大长度767bytes 若使用utf8mb4格式编码(utf8字符占用3字节,utf8mb4字符占用4字节) 则单个字段长度不能超过191 5.7及之后版本, 限制放开到3072 bytes 解决方案一、将数据库版本升级到5.7版本或以上 二、修改相关配置,增加操作以解决 解决方案如下:
innodb_large_prefix = ON innodb_file_format = Barracuda innodb_file_per_table = ON
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; 这样做的缺点会造成查询性能下降 总结以上为个人经验,希望能给大家一个参考,也希望大家多多支持 。 |