您好,登錄后才能下訂單哦!
小編給大家分享一下怎么解決Laravel5.x的php artisan migrate數據庫遷移創建操作報錯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的php artisan migrate數據庫遷移創建操作報錯SQLSTATE[42000]”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。