質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
86.02%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

受付中

Laravelのマイグレーションファイルの生成に関する質問

yuyuyu101
yuyuyu101

総合スコア1

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

1回答

0グッド

0クリップ

403閲覧

投稿2022/11/07 15:23

前提

Laravelの練習のために基本的な機能を持つデータ入力システムを作成しています。
「php artisan migrate」によってmigrateを行いましたが、エラーメッセージが出てしまうため、解決したいです。

実現したいこと

マイグレーションファイルの生成を行いたいです。

発生している問題・エラーメッセージ

※コマンドプロンプトで「php artisan migrate」を行った時のエラー内容です。

cmd

1 INFO Running migrations. 2 2022_11_07_030830_create_people .......................................................................... 64ms FAIL 3 Illuminate\Database\QueryException 4 SQLSTATE[HY000]: General error: 1 table "people" already exists (SQL: create table "people" ("id" integer not null primary key autoincrement, "id" integer not null primary key autoincrement, "name" varchar not null, "mail" varchar not null, "memo" varchar not null, "age" integer not null, "created_at" datetime, "updated_at" datetime)) 5 at C:\Users\murai\Documents\Laravelapp\vendor\laravel\framework\src\Illuminate\Database\Connection.php:760 6 756▕ // If an exception occurs when attempting to run a query, we'll format the error 7 757▕ // message to include the bindings with SQL, which will make this exception a 8 758▕ // lot more helpful to the developer instead of just the database's errors. 9 759▕ catch (Exception $e) { 10 ➜ 760▕ throw new QueryException( 11 761▕ $query, $this->prepareBindings($bindings), $e 12 762▕ ); 13 763▕ } 14 764▕ } 15 1 C:\Users\murai\Documents\Laravelapp\vendor\laravel\framework\src\Illuminate\Database\Connection.php:539 16 PDOException::("SQLSTATE[HY000]: General error: 1 table "people" already exists") 17 2 C:\Users\murai\Documents\Laravelapp\vendor\laravel\framework\src\Illuminate\Database\Connection.php:539 18 PDO::prepare("create table "people" ("id" integer not null primary key autoincrement, "id" integer not null primary key autoincrement, "name" varchar not null, "mail" varchar not null, "memo" varchar not null, "age" integer not null, "created_at" datetime, "updated_at" datetime)")

関連ファイルのソースコード

C:\Users\murai\Documents\Laravelapp\database\migrations

2022_11_07_030830_create_people.php

1<?php 2 3use Illuminate\Database\Migrations\Migration; 4use Illuminate\Database\Schema\Blueprint; 5use Illuminate\Support\Facades\Schema; 6 7return new class extends Migration 8{ 9 /** 10 * Run the migrations. 11 * 12 * @return void 13 */ 14 public function up() 15 { 16 Schema::create('people', function (Blueprint $table) { 17 $table->id(); 18 19 $table->increments('id'); 20 $table->string('name'); 21 $table->string('mail'); 22 $table->string('memo'); 23 $table->integer('age'); 24 25 $table->timestamps(); 26 }); 27 } 28 29 /** 30 * Reverse the migrations. 31 * 32 * @return void 33 */ 34 public function down() 35 { 36 Schema::dropIfExists('people'); 37 } 38};

補足情報(FW/ツールのバージョンなど)

Laravel Framework 9.38.0

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

AbeTakashi

2022/11/07 16:37

PDOException::("SQLSTATE[HY000]: General error: 1 table "people" already exists") に原因がまるっとそのまま書いてありますが・・・ エラーメッセージは読んでませんか? それともこのエラーの内容の意味は分かっている上で、その対応方法が分からないということでしょうか?
yuyuyu101

2022/11/07 22:42

コメントありがとうございます。 「Peopleテーブルはすでに存在する」という部分がエラー原因であると認識しています。 そのうえで対処が分からない状況です。(エラーの把握も確かな自信はありません) エラー文を検索などしてみたのですが、現状打破できず苦慮しています。 ※書き忘れていましたが、私の環境はWindows11となります。
m.ts10806

2022/11/07 22:51

作りたいテーブルがすでにあるならマイグレーションする必要ないのでは。 どういう結果(今回は生成内容?)を期待しているのでしょうか。
yuyuyu101

2022/11/07 23:16

コメントありがとうございます。 マイグレーションを試すために、databaseフォルダ内のdatabase.sqliteファイルを一旦ほかの場所へ移動してから、そこへ空のデータベースファイルを新たに作成し(その際、touchコマンドが使えない為、代わりにtype nulコマンドを使用)、migrateをためした結果このエラーになった流れです。 今は参考にしている書籍を読み進めながらなぞっており、以下の結果を得ることができず試行錯誤しています。 ・期待している結果は以下のマイグレーションが実行されることです。  ```cmd Migration table created susessfully Migrating: xxxx_create_users_table Migrated: xxxx_create_users_table Migrating: xxxx_create_password_reset_table Migrated: xxxx_create_password_reset_table Migrating: xxxx_create_people_table Migrated: xxxx_create_people_table ```
AbeTakashi

2022/11/08 01:31 編集

エラー内容を認識しつつ対応方法が分からない件や環境情報(SQLiteやWindowsを利用してる)はかなり大事な情報なので質問文に追記した方がいいと思います。あとタイトルも「マイグレーションファイルの生成」よりは「マイグレーションの実行」ですよね。ちょっと紛らわしい感じを受けました。 自分はLaravelでSQLite使ったことないのでその状況はよく分かりませんが、単純にConfigで設定しているdatabase.sqliteとは別のファイルを移動してるのでは?とか、あとはConfigがしっかり反映されてない可能性があるので php artisan config:cache してみるとかくらいしか思いつきません。
m.ts10806

2022/11/08 23:11

質問は編集できますので、本文に追記を。

回答1

1

マイグレーションを実行する
前回実行したものは実行せず、追加されたものだけ実行する。
実行したものは migrations テーブルに保存されている。

php artisan migrate

既存のテーブルを一旦削除してマイグレーションを実行する
開発中で、リリースしていない場合はこちらで実行しても問題ない

php artisan migrate:fresh

down を実行した上で、マイグレーションを実行する

php artisan migrate:refresh

https://readouble.com/laravel/8.x/ja/migrations.html

投稿2022/11/08 06:05

phper.k

総合スコア3714

m.ts10806👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

yuyuyu101

2022/11/16 04:23

コメントありがとうございます。 php artisan migrate:fresh php artisan migrate:refresh を行ったあと、マイグレートをしましたが、 INFO Nothing to migrate. というエラーが発生しています。
phper.k

2022/11/16 04:50

ちゃんと意味あ目的もわからずに使っても解決しないよ

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
86.02%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。