【Laravel】シーディング機能を使用してダミーデータを作成する

目次

シーティングとは

ダミーのレコードを登録する処理を記述しておく機能

1. シーダーファイルの作成

以下のコマンドを実行します。

1
php artisan make:seeder 【テーブル名TableSeeder】

2. ダミーデータの追記

1の手順で作成したファイルは、「アプリケーションディレクトリ/database/seeders/」ディレクトリ内に生成されています。

use Illuminate\Support\Facades\DB;の追記が必要が必要です

処理としては、連想配列をクエリビルダーで挿入するだけです。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<?php

namespace Database\Seeders;

use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB;

class PeopleTableSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
// ここに処理を記述します
DB::table('テーブル名')->insert([
[
'キー' => '値',
'キー' => '値',
],
[
'キー' => '値',
'キー' => '値',
],
[
'キー' => '値',
'キー' => '値',
],
]);
}
}

3. シーダーファイルの登録

作成した、シーディングファイルは、そのままでは実行されません。コマンドでシーディングが実行されるように、DatabaseSeederに登録する必要があります。

「アプリケーションディレクトリ/database/seeders/」ディレクトリ内にLaravelのイニシャライズ時に生成されていたファイルDatabaseSeeder.phpを編集します

はじめに開くと、以下のような内容になっていると思います。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php

namespace Database\Seeders;

use Illuminate\Database\Seeder;

class DatabaseSeeder extends Seeder
{
/**
* Seed the application's database.
*
* @return void
*/
public function run()
{
// \App\Models\User::factory(10)->create();
}
}

runメソッドに以下のように追記していきます。

callメソッドは設定されたクラスのrunメソッドを呼び出します。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
namespace Database\Seeders;

use Illuminate\Database\Seeder;

class DatabaseSeeder extends Seeder
{
/**
* Seed the application's database.
*
* @return void
*/
public function run()
{
// \App\Models\User::factory(10)->create();
$this->call(シーダークラス名::class);
}
}

4. シーディングの実行

1
php artisan db:seed

【Laravel】シーディング機能を使用してダミーデータを作成する

https://blog.djima.net/2021/06/10/【Laravel】シーディング機能を使用してダミーデータを作成する/

Author

Daiki Iijima

Posted on

2021-06-10

Updated on

2024-04-17

Licensed under