Specified key was too long; max key length is 767 bytes错误的原因

mysql数据库里某个UNIQUE唯一索引字段从utf8改为utf8mb4时提示1071 - Specified key was too long; max key length is 767 bytes,来看看这个错误的来原因。

来几个知识点

  • 一个字符latin1占用1 bytesutf8占用3 bytes,而utf8mb4占用4 bytes
  • mysql5.6以及以前的版本的InnoDB引擎的表限制索引最多占用767 bytes;而MyISAM的是最长1000 bytes
  • mysql5.7版本开始这个限制提升到3072 bytesUTF8可以达到VARCHAR(1024)

所以当你的唯一索引字段在mysql5.6或更早的版本时(引擎为InnoDB),utf8mb4字符串最长能到VARCHAR(191)(1914=764),utf8可以到VARCHAR(255)(255·3=765)。如果你从不指定长度直接使用utf8mb4字段做唯一索引,就会报Specified key was too long; max key length is 767 bytes错误,因为计算默认字符串默认长度时是255。

这个问题在Laravel中就有可能发生,为了存储emoji它默认使用utf8mb4,如果你的mysql版本低于5.7,需要注意上面的情况.

参考:https://beltxman.com/2297.html

posted @   哩个啷个波  阅读(3164)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示