1050 Base table or view already exists 本番環境でのマイグレーションエラー3対策

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

本番環境でマイグレート実行した時に、[base table or view already exists] エラーが出たときの対策です。

ロールバック、テーブル削除、リフレッシュの3つの対策を解説します。

だんだんと過激な対策になっていきます。

まずは最初のマイルドな方法から試してみてください。

Git Pullエラー1050:Base table or view already exists 3対策

エラーの意味は「マイグレートしようとしているテーブル、既にあるよ」というもの。

まずは問題のテーブルを突き止めましょう。

【マイルドな対策】ロールバックで処理のやり直し

問題のテーブルをつきとめたら、そのテーブルを作成するところまでロールバックします。

その後、マイグレートをやり直してみましょう。

なお、このエラーはテーブルに修正を加えてしまった時などに起こりがちです。(←経験則)

たとえば、テーブル名を変えたり、データ型を変更したり。

もし該当する場合には、ロールバックを実行後、こういった変更処理のマイグレーションファイルは削除してください。

最初から正しい情報でマイグレーションファイルを作成した後php aritsan migrate  を実行します。

じゅんこ
じゅんこ

力技でロールバックせずに修正を「なかったことに」する手でもOKです^^;

【少し過激な対策】テーブルを削除する

2つ目の方法は少し過激になります。

テーブルを削除してしまう方法です。

①データをエクスポートする

テーブル内にデータが入っている場合は、一度エクスポートしておいてください。

②テーブル削除します。

xserverのphpmyadminであれば、ログイン後、該当のテーブルを選択します。

「操作」タブをクリック

右側の「テーブルを削除する」を選択します。

③マイグレートを実施

削除後に再度、 php artisan migrate  を実行します。

無事にできていたら、エクスポートしたデータをインポートします。

【過激な対策】全部やりなおし

上記の方法でだめなら、全部やりなおしという手があります。

リフレッシュを行うと、すべてのマイグレーションをロールバックしてなかったことにできます。

さらに、最後に マイグレートをかけてくれます。

ただ当然ながら、テーブル内のデータは消えてしまうので、データが既に入っているときには、ご注意ください。

 

じゅんこ
じゅんこ

マイルドな方法から試してみてくださいね。

エラーの解決、祈っております!

 

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

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

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

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

【無料プレゼント】

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

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

詳細はこちらをクリック

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

Laravelの本を書きました。


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

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

書籍の詳細を見てみる

Laravelの本を書きました。


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

Laravel10対応

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

書籍の詳細を見てみる

 

Laravelの教科書限定コミュニティ【Laravelの教科書ラボ】はじめました。
デプロイ講座付。StripeやChatGPT連携など過去10回分のセミナー動画視聴可能。

Laravel実践スキルをのばしたい方におすすめです。

ラボの案内を見てみる

Twitter始めました。
40代からプログラミング!
タイトルとURLをコピーしました