Laravel 常见错误 1071 Specified key was too long

Laravel与Mysql索引长度超限解决方案
本文详细解析了在使用Laravel5.5与Mysql5.5进行数据库迁移时遇到的索引长度超过1000字节的问题。探讨了Mysql不同版本及存储引擎对索引长度的限制,并提供了三种有效的解决策略:更改存储引擎为InnoDB,调整字符集减少字符占用空间,以及优化字段长度。同时,文中还介绍了如何在Laravel中修改字符串长度的默认值。

Laravel 5.5 + Mysql 5.5 ,执行 migrate 时,提示索引长度超过指定的 1000 bytes

 

 

原因:

  Mysql 对索引有一定的长度限制,版本不同长度不同;

  MyIsAm 长度小于 InnoDB 长度。

解决:

  1、将 Mysql engine 修改为 innodb;

  2、修改字符,默认为 utf8,一个字符占 3 bytes;

  3、修改表中字段长度,不超过限制;

    在 Laravel 中,编辑 \app\Providers\AppServiceProvider.php,在 boot 方法中,定义 stringlength 的默认值

 

转载于:https://www.cnblogs.com/rendd/p/10244361.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值