Database QueryException Column already exists:マイグレーションエラー

Laravel・PHP豆知識・トラブル対策

Rollbackをしてもマイグレーションエラーが繰り返されて、こんなメッセージが出てくるとき。

Illuminate/Database/QueryException
SQLSTATE[42S21]: Column already exists:

追加したりリネームしたカラムが原因かもしれません。(←私がそうでした!)

マイグレーションファイルに削除のときのコードを書き忘れた、あるいは書き間違えている可能性があります。

思い当たる場合には、マイグレーションファイルで下記の2点をチェックしてみてくださいね。

カラムを追加したときはdropColumnを忘れずに

カラムを追加したときには、マイグレーションファイルのfunction down () にdropColumnを追加します。

たとえば division_id カラムを追加した場合には、下記のコードを入れます。

編集後のファイルはこちら。

きちんと入っているか、確認してみてください。

カラム名を変更したときは順番を間違えないように

カラム名を変更する場合、たとえば player_id を worker_id に変更する場合は、マイグレーションファイルのfunction up ()に次のようにいれます。

function down () には、このカラム名を逆にしていれておきましょう。

なぜなら、削除するときにはカラム名をもとに戻す必要があるからです。

編集後のファイルはこちら。

ちょっとややこしいのですが、きちんと設定しておかないと、ロールバックしても、きれいに削除できません。

すると、そのあとにマイグレートを実施する時にエラーメッセージが表示されます。

なおマイグレーションのやり直し方法はこちらの記事を参考にしてください。

エラー対策はこちらにまとめてあります。

Laravel・PHP豆知識・トラブル対策

【Laravelの教科書・プレゼント】

Junko
Laravelの使い方を覚えたい!と思ったら、ぜひ、役立ててほしいです。 基礎編は無料でプレゼント中です♪
ひつじプログラマ
会員制サイトをいちから作っていくよ。ボタンをクリックして詳細を見てね。
Laravelの教科書の詳細を見る

最新のLaravel11版テキストに加え、Laravel8版・Laravel9版・Laravel10版もご用意しています♪

【無料プレゼント】

「LaravelでWebアプリをいちから作れるようになりたい!」

そんなLaravel初心者のあなたへ【Laravelの教科書】基礎編プレゼント中! 会員制フォーラムサイトを学習しながら作れます。

詳細はこちらをクリック

最新のLaravel11版テキストに加え、Laravel8版・Laravel9版・Laravel10版もご用意しています♪

【AWS関連・Webアプリ開発・生成AIのAPI活用のご相談承ってます】
お気軽にお声がけください。
御社にとって、最善の方法をご一緒に考えてまいります。
Zoomミーティング実施中。サンプルアプリご利用可能です。

お問合せフォーム

Laravelの本を書きました。


ひつじが目印♪
クリックするとamazonページへ。

Laravelの使い方を分かりやすく解説した書籍を出版しました。書店やAmazon等のオンラインショップにて販売中です。
Laravel10対応。Laravel11サポートガイドもご用意しています。詳しくは下記ボタンをクリック♪

書籍の詳細を見てみる

Laravelの本を書きました。


ひつじが目印♪
クリックするとamazonページへ。

最新版Laravel11用のサポートガイドご用意しています。

Laravelの使い方を分かりやすく解説した書籍を出版しました。書店やAmazon等のオンラインショップにて販売中です。

書籍の詳細を見てみる
Twitter始めました。
40代からプログラミング!
タイトルとURLをコピーしました