使用 seed 命令建立模擬資料(學習筆記)

NaturalGao發表於2019-05-13

在開發環境中,我們經常會使用 “模擬資料” 來測試我們應用,在laravel 中 提供了 ”資料填充“來幫助我們實現這個需求。我們現在就來用這個功能來建立 20個使用者...

1.1 開啟新建立的laravel專案 database/migrations目錄 下可以發現 兩個檔案 一個是建立使用者表的,一個是建立確認密碼錶的(圖中沒看到是因為我刪除了)

使用seed命令建立模擬資料

1.2 我們可以開啟這個檔案瞧瞧 (根據實際情況修改,這裡我就不修改了)

<?php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateUsersTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('name');
            $table->string('email')->unique();
            $table->timestamp('email_verified_at')->nullable();
            $table->string('password');
            $table->rememberToken();
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('users');
    }
}

1.3 執行 artisan 命令 生成表

php artisan migrate

於是生成了 users 表

使用seed命令建立模擬資料

2.1 使用 artisan 命令生成 UsersTableSeeder.php 檔案

php artisan make:seed UsersTableSeeder

命令執行後,我們可以在 database/seeds 目錄下發現多了個我們建立的UsersTableSeeder.php檔案

使用seed命令建立模擬資料

我們開啟這個檔案:

<?php

use Illuminate\Database\Seeder;

class UsersTableSeeder extends Seeder
{
    /**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {

    }
}

接著我們修改一下這個檔案(建立20個使用者):

<?php

use Illuminate\Database\Seeder;

class UsersTableSeeder extends Seeder
{
    /**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {
    //使用 factory 來建立模擬資料
        factory(\App\User::class,20)->create();
    }
}

同目錄下還有個 DatabaseSeeder.php 檔案,我們需要 讓這個檔案 執行 我們這個新建立的UsersTableSeeder.php檔案,所以需要把 run方法中的 $this->call(UsersTableSeeder::class) 的註釋取消掉

<?php

use Illuminate\Database\Seeder;

class DatabaseSeeder extends Seeder
{
    /**
     * Seed the application's database.
     *
     * @return void
     */
    public function run()
    {
         $this->call(UsersTableSeeder::class);
    }
}

3.1 database/factories 目錄下有 個 UserFactory.php 檔案,修改為(根據實際情況):

<?php

/** @var \Illuminate\Database\Eloquent\Factory $factory */
use App\User;
use Illuminate\Support\Str;
use Faker\Generator as Faker;

/*
|--------------------------------------------------------------------------
| Model Factories
|--------------------------------------------------------------------------
|
| This directory should contain each of the model factory definitions for
| your application. Factories provide a convenient way to generate new
| model instances for testing / seeding your application's database.
|
*/

$factory->define(User::class, function (Faker $faker) {
    return [
        'name' => $faker->name,
        'email' => $faker->unique()->safeEmail,
        'email_verified_at' => now(),
        'password' => bcrypt('123456'), // password
        'remember_token' => Str::random(10),
    ];
});

3.2 生成模擬資料,執行以下 artisan 命令:

php artisan db:seed

開啟 users 表可以發現新建立了20條使用者資料:

使用seed命令建立模擬資料

這樣就可以生成模擬資料啦,是不是很簡單呢~~~ 如果有幫助到你,給個讚唄!

特別宣告: 本人只是菜鳥,記錄一下平時學習筆記,高手莫噴,謝謝!

相關文章