laravel mysql 1071_laravel6数据库迁移报错: Syntax error or access violation: 1071 Specified key was too lon...

laravel又报错了,这次是执行数据库迁移的时候报的错,迁移命令为 php artisan migrate,报错信息为 Syntax error or access violation: 1071 Specified key was too long如下图:

48fb3c162621e684801754b9dc77356b.png

先说一下这里使用的laravel版本为laravel6版本,而laravel6默认使用 utf8mb4 字符,它支持在数据库中存储 "emojis" 。如果你是在MySQL版本低于 5.7.7 的数据库上创建索引,那就需要你手动配置迁移生成的默认字符串长度。

其实这个问题在laravel的官方手册数据库迁移部分已经明确过了,小伙伴们可以重新翻一下laravel的官方手册。懒得翻的小伙伴,下图是laravel对于这部分的解释:

c3b7ecc149b41b1360453b3a5975dba1.png

根据laravel手册的方法就是打开app/Prpvider/AppServiceProvider.php文件找到里面的boot方法,然后就是:use Illuminate\Support\Facades\Schema;

public function boot(){

Schema::defaultStringLength(191);

}

这样问题就解决了。其实就算执行数据库迁移的时候报了这个错误,数据库还是已经正常创建了。但是毕竟有错误感觉不爽不是?

当然还有其它的解决方法,你可以用$table->engine = 'InnoDB';将数据库引擎修改为InnoDB,这样也可以解决。或者你直接修改字符集为utf-8也行,反正方法很多,不过推荐还是用官方的来吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值