修改Mysql索引长度限制解决767 byte限制问题

2024-04-16 0 749
目录
  • 报错
  • 原因
  • 解决方案
  • 这样做的缺点
  • 总结

报错

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;

这样做的缺点

会造成查询性能下降

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源网。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 Mysql 修改Mysql索引长度限制解决767 byte限制问题 https://www.u-9.cn/database/mysql/185406.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务