修改Mysql索引长度限制解决767 byte限制问题
更新时间:2024年03月29日 09:38:39 作者:贝小贝貝
这篇文章主要介绍了修改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;
这样做的缺点
会造成查询性能下降
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别
本文给大家分享的是mysql索引中的KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别,即主键索引,唯一索引和普通索引的区别,希望大家能够喜欢2017-07-07
最新评论