Readouble

Laravel 4.2 マイグレーションと初期値設定

イントロダクションIntroduction

マイグレーションはデータベースのバージョンコントロールの一種です。これはデータベーススキーマの修正と現状のスキーマの状態を最新状態に保つことを両立させてくれます。典型的なマイグレーションはアプリケーションのスキーマを簡単に管理するためのスキーマ・ビルダーと一緒に使用されます。Migrations are a type of version control for your database. They allow a team to modify the database schema and stay up to date on the current schema state. Migrations are typically paired with the Schema Builder[/docs/4.2/schema] to easily manage your application's schema.

マイグレーションの生成Creating Migrations

マイグレーションを作成するには、Artisanコマンドラインツールでmigrate:makeコマンドを実行します。To create a migration, you may use the migrate:make command on the Artisan CLI:

php artisan migrate:make create_users_table

マイグレーションはapp/database/migrationsフォルダーに設置され、マイグレーションの順番をフレームワークに知らせるため、名前にタイムスタンプが含まれています。The migration will be placed in your app/database/migrations folder, and will contain a timestamp which allows the framework to determine the order of the migrations.

さらにマイグレーションを作成時に--pathオプションを指定できます。インストールしたルートディレクトリーからの相対パスを指定します。You may also specify a --path option when creating the migration. The path should be relative to the root directory of your installation:

php artisan migrate:make foo --path=app/migrations

--table--createオプションもテーブル名、マイグレーションで新しいテーブルを生成するかを指定するために使用できます。The --table and --create options may also be used to indicate the name of the table, and whether the migration will be creating a new table:

php artisan migrate:make add_votes_to_user_table --table=users

php artisan migrate:make create_users_table --create=users

マイグレーションの実行Running Migrations

未実行の全マイグレーションを実行するRunning All Outstanding Migrations

php artisan migrate

指定されたパスの全未実行マイグレーションを実行するRunning All Outstanding Migrations For A Path

php artisan migrate --path=app/foo/migrations

パッケージの全未実行マイグレーションを実行するRunning All Outstanding Migrations For A Package

php artisan migrate --package=vendor/package

注目:"class not found"エラーがマイグレーション実行時に発生する場合は、composer dump-autoloadコマンドを実行してみてください。Note: If you receive a "class not found" error when running migrations, try running the composer dump-autoload command.

実働環境でマイグレーションを強制するForcing Migrations In Production

いくつかのマイグレーション操作は破壊的です。つまり、データーを失う可能性があります。実働環境のデータベースでこうしたコマンドを実行してしまうことを守るために、コマンドが実行される前に、確認のプロンプトが表示されます。このようにコマンド実行時のプロンプトを出さないためには、--forceフラグを指定してください。Some migration operations are destructive, meaning they may cause you to lose data. In order to protect you from running these commands against your production database, you will prompted for confirmation before these commands are executed. To force the commands to run without a prompt, use the --force flag:

php artisan migrate --force

マイグレーションのロールバックRolling Back Migrations

最後のマイグレーション操作をロールバックするRollback The Last Migration Operation

php artisan migrate:rollback

全マイグレーションをロールバックするRollback all migrations

php artisan migrate:reset

全マイグレーションをロールバックし、再度全部実行するRollback all migrations and run them all again

php artisan migrate:refresh

php artisan migrate:refresh --seed

データベース初期値設定Database Seeding

更に初期値設定(seed)クラスを使用し、テストデーターをデーターベースに設定する、シンプルな方法もLaravelには備わっています。全部の初期値設定クラスはapp/database/seedsに保存されます。初期値設定クラスには好きな名前を付けられます。ですがUserTableSeederなどのような分かりやすい規則に従ったほうが良いでしょう。デフォルトとして、DatabaseSeederクラスが定義されています。このクラスから、callメソッドを使い他の初期値設定クラスを呼び出すことで、値を設定する順番をコントロールできます。Laravel also includes a simple way to seed your database with test data using seed classes. All seed classes are stored in app/database/seeds. Seed classes may have any name you wish, but probably should follow some sensible convention, such as UserTableSeeder, etc. By default, a DatabaseSeeder class is defined for you. From this class, you may use the call method to run other seed classes, allowing you to control the seeding order.

データベース初期値設定の例Example Database Seed Class

class DatabaseSeeder extends Seeder {

	public function run()
	{
		$this->call('UserTableSeeder');

		$this->command->info('User table seeded!');
	}

}

class UserTableSeeder extends Seeder {

	public function run()
	{
		DB::table('users')->delete();

		User::create(array('email' => 'foo@bar.com'));
	}

}

データベースに初期データーを設置するには、Artisanコマンドラインツールでdb:seedコマンドを使ってください。To seed your database, you may use the db:seed command on the Artisan CLI:

php artisan db:seed

デフォルトでは、db:seedコマンドは、他の初期値設定クラスを呼び出しているDatabaseSeederクラスを実行します。個別に初期値設定クラスを呼び出したい場合は、--classオプションを指定して実行することができます。By default, the db:seed command runs the DatabaseSeeder class, which may be used to call other seed classes. However, you may use the --class option to specify a specific seeder class to run individually:

php artisan db:seed --class=UserTableSeeder

またmigrate:refreshコマンドを使用し、マイグレーションを全部ロールバックし、再度実行することでも、初期データーを設置できます。You may also seed your database using the migrate:refresh command, which will also rollback and re-run all of your migrations:

php artisan migrate:refresh --seed

章選択

Artisan CLI

設定

明暗テーマ
light_mode
dark_mode
brightness_auto システム設定に合わせる
テーマ選択
photo_size_select_actual デフォルト
photo_size_select_actual モノクローム(白黒)
photo_size_select_actual Solarized風
photo_size_select_actual GitHub風(青ベース)
photo_size_select_actual Viva(黄緑ベース)
photo_size_select_actual Happy(紫ベース)
photo_size_select_actual Mint(緑ベース)
コードハイライトテーマ選択

明暗テーマごとに、コードハイライトのテーマを指定できます。

テーマ配色確認
スクリーン表示幅
640px
80%
90%
100%

768px以上の幅があるときのドキュメント部分表示幅です。

インデント
無し
1rem
2rem
3rem
原文確認
原文を全行表示
原文を一行ずつ表示
使用しない

※ 段落末のEボタンへカーソルオンで原文をPopupします。

Diff表示形式
色分けのみで区別
行頭の±で区別
削除線と追記で区別

※ [tl!…]形式の挿入削除行の表示形式です。

テストコード表示
両コード表示
Pestのみ表示
PHPUnitのみ表示
OS表示
全OS表示
macOSのみ表示
windowsのみ表示
linuxのみ表示
和文変換

対象文字列と置換文字列を半角スペースで区切ってください。(最大5組各10文字まで)

本文フォント

総称名以外はCSSと同様に、"〜"でエスケープしてください。

コードフォント

総称名以外はCSSと同様に、"〜"でエスケープしてください。

保存内容リセット

localStrageに保存してある設定項目をすべて削除し、デフォルト状態へ戻します。

ヘッダー項目移動

キーボード操作