laravel数据库迁移报错怎么回事?如何解决?
Admin 2021-05-10 群英技术资讯 1731 次浏览
这篇文章主要给大家分享的是有关解决laravel数据库迁移报错SQLSTATE[42000]的内容,很多朋友遇到这个问题不知怎么解决,因此分享给大家做个参考,有需要的朋友可以看一下。
Illuminate\Database\QueryException : SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes (SQL: alter table `users` add unique `users_email_unique`(`email`))

以上报错是因为你的数据库版本低于当前laravel要求,laravel现在默认utf8mb4包括存储emojis支持。如果你运行MySQL v5.7.7或者更高版本,则不会报这个错误。
1、找到/app/Providers/AppServiceProvider.php文件添加以下代码(如图)
Schema::defaultStringLength(191);

2、再次运行:php artisan migrate
显示如下:
In AppServiceProvider.php line 16: Class 'App\Providers\Schema' not found

3、还是/app/Providers/AppServiceProvider.php文件添加以下代码(如图)
use Illuminate\Support\Facades\Schema;

4、再次运行:php artisan migrate
(1) 如果有这个报错:
Illuminate\Database\QueryException : SQLSTATE[42S01]: Base table or view already exists:
需要删除数据库里的表,然后再php artisan migrate

(2)数据库迁移创建成功

关于Laravel5.x数据库迁移报错SQLSTATE[42000]的解决办法介绍就到这,大家能够按照上述步骤操作解决,希望本文对大家有帮助,想要了解更多laravel数据库迁移报错的内容大家可以继续关注其他文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
如何实现表单处理, GET 和 POST 都创建数组(例如,array( key => value, key2 => value2, key3 => value3, ...))。此数组包含键/值对,其中的键是表单控
swoole关闭进程的方法:首先把代码里的守护进程改成0;然后通过命令“netstat -apn | grep 9503”查找这个端口号的pid;接着使用命令“kill -9 18669”杀死这个进程;最后重新开启监听程序即可。
Swoole在1.8.6版本提供了全新的异步MySQL客户端,底层自行实现了MySQL的通信协议,无需依赖其他第三方库,直接使用swoole_mysql->__construct命令,创建异步mysql客户端。
laravel怎样实现批量更新数据?我们知道Laravel框架中有批量插入数据的方法,但是没有批量更新的方法,如果要每条数据都执行一次,那么不仅速度慢而且会占用更多的资源。对此,这篇文章就给大家分享一下laravel实现批量更新多条数据的方法。
php终止脚本执行的方式有哪些?首先我们需要知道终止脚本执行是什么意思。终止脚本执行,就是指通过一条语句告诉PHP引擎,此语句之后的其他语句不需要执行。下面我们就具体看看php终止脚本执行的方式。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008