2017-04-01 22 views
0

laravel 5.4でmigrateコマンドを実行すると「特定のキーが長すぎます」というエラーが表示され、多くの人がこのエラーに直面しています。一般的なものは、にSchema::defaultStringLength(191);を追加したものです。しかし、文書https://laravel-news.com/laravel-5-4-key-too-long-errorは、5.7.7より前のmysqlバージョン用です。しかし、私のバージョンは5.7.14(mysql Ver 14.14 Distrib 5.7.14, for Win64 (x86_64))で、utf8mb4(show variables like "%char%")へのI既に設定されているMySQLのデフォルトの文字セット:Laravel 5.4 migrateキーが長すぎるエラー

enter image description here

だから、私は何も変更する必要はありませんが、私はまだ問題を得ると思います。それは私を混乱させます。誰が私を助けられるか?ありがとう。

+0

マイグレーションで一意の複合キーが定義されていますか? – dparoli

答えて

0

innodb_large_prefixOnに設定してください。 documentationによれば、Mysql> = 5.7.7ではデフォルトにする必要がありますが、非標準設定を使用することもできます。

1
  1. セットinnodb_file_format=Barracuda
  2. セットinnodb_large_prefix=1
  3. セットinnodb_default_row_format=dynamic

ステップ1(innodb_file_format)及び2(innodb_large_prefix)MariaDB含む古いMySQLバージョン、上で動作します。私はこれらのバージョンの下限を知らない。これらの設定についてはMysql 5.7.7 changed the defaultsがありましたが、以前は存在していました。

ステップ3(innodb_default_row_format)には、5.7.9以上のMySQLが必要です。

説明のため、 innodb_default_row_format設定がない場合の回避策は、エンジンinnodb row_format=dynamicを使用することです。これは、LaravelがこれをエスケープせずにCREATE TABLEステートメントに追加し、... ENGINE=innodb row_format=dynamicという結果になるという事実を悪用します。

Laravel 5.2.14 introduced the ability to specify the engineconfig/database.php。古いバージョンの場合は、テーブルを作成するすべての移行でこれを指定する必要があります。 $table->engine = 'innodb row_format=dynamic';

関連する問題