Fork me on GitHub

MySQL错误“Specified key was too long; max key length is 1000 bytes”的解决办法

MySQL错误“Specified key was too long; max key length is 1000 bytes”的解决办法


 

最近在处理执行 Flowable 6.5.0 官方提供的 MySQL 数据库语句脚本的时候,

当执行到数据库中的某三个字段设置unique索引的时候,遇到了“Specified key was too long; max key length is 1000 bytes”这样的报错。

 

问题原因

MySQL 在建立索引时,数据库会先计算Index用到的字段长度(按下面比例乘起来不能超过限定的key长度1000):
latin1 = 1 byte = 1 character
uft8 = 3 byte = 1 character
gbk = 2 byte = 1 character

比如:

两个字段长度均设置为255,当为utf8时,索引字段的长度为:(255*3+255*3)= 1530 > 1000

 

解决方案

调整字段的长度,让索引占用的字节长度小于 1000,就可以正常创建索引

比如:

将字段长度由255调整为127 ,这样上述的情况:(127*3+127*3)= 762 < 1000

 

posted @   龙凌云端  阅读(8298)  评论(1编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示