Specified key was too long; max key length is 767 by

来几个知识点

  • 一个字符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,需要注意上面的情况.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值