「Mysql::Error: 指定されたキーが長すぎます。最大キー長は 1000 バイトです」のトラブルシューティング
次のコマンドを実行しようとするとコマンド:
script/generate acts_as_taggable_on_migration rake db:migrate
error:
Mysql::Error: Specified key was too long; max key length is 1000 bytes: CREATE INDEX `index_taggings_on_taggable_id_and_taggable_type_and_context` ON `taggings` (`taggable_id`, `taggable_type`, `context`)
原因
このエラーは、MySQL のストレージ エンジンによってインデックスのサイズに課せられた制限が原因で発生します。 Ruby on Rails で一般的に使用される MyISAM エンジンでは、インデックス サイズが 1,000 バイトに制限されています。
解決策
この問題を解決するには、次の戦略を検討してください。
CREATE INDEX example_idx_id ON YOUR_TABLE(taggable_id) CREATE INDEX example_idx_type ON YOUR_TABLE(taggable_type)
追加の構成
データベースのエンコード設定で示されているように、データベースはlatin1 文字エンコーディングを使用するように構成されています。これにより、UTF-8 エンコーディングを使用する列のインデックスの有効性が制限される可能性があります。インデックスのパフォーマンスを向上させるには、データベースを UTF-8 エンコードに変換することを検討してください。
以上がMySQL エラーを解決する方法:「指定されたキーが長すぎます。最大キー長は 1000 バイトです」?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。