翼度科技»论坛 编程开发 mysql 查看内容

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

8

主题

8

帖子

24

积分

新手上路

Rank: 1

积分
24
报错
  1. 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中修改配置:
  1. innodb_large_prefix = ON
  2. innodb_file_format = Barracuda
  3. innodb_file_per_table = ON
复制代码

  • 2、在create中添加row_format=dynamic
  1. create table sql_test(
  2. id int ,
  3. name VARCHAR(200),
  4. server_id VARCHAR(30),
  5. id_num1 VARCHAR(30),
  6. id_num2 VARCHAR(30),
  7. link VARCHAR(500),
  8. PRIMARY KEY (id),
  9. KEY sql_test_name (name))
  10. engine=innodb row_format=dynamic;
复制代码
这样做的缺点

会造成查询性能下降

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

来源:https://www.jb51.net/database/318866zmg.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具