使用 seed 命令建立模擬數據(學習筆記)

在開發環境中,咱們常常會使用 「模擬數據」 來測試咱們應用,在laravel 中 提供了 」數據填充「來幫助咱們實現這個需求。咱們如今就來用這個功能來建立 20個用戶...php

1.使用 artisan 命令生成 用戶表

1.1 打開新建立的laravel項目 database/migrations目錄 下能夠發現 兩個文件 一個是建立用戶表的,一個是建立確認密碼錶的(圖中沒看到是由於我刪除了)laravel

使用seed命令建立模擬數據

1.2 咱們能夠打開這個文件瞧瞧 (根據實際狀況修改,這裏我就不修改了)app

<?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 命令 生成表dom

php artisan migrate

因而生成了 users 表ide

使用seed命令建立模擬數據

2. 生成seed文件,而且修改

2.1 使用 artisan 命令生成 UsersTableSeeder.php 文件學習

php artisan make:seed UsersTableSeeder

命令執行後,咱們能夠在 database/seeds 目錄下發現多了個咱們建立的UsersTableSeeder.php文件測試

使用seed命令建立模擬數據

咱們打開這個文件:this

<?php

use Illuminate\Database\Seeder;

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

接着咱們修改一下這個文件(建立20個用戶):spa

<?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) 的註釋取消掉3d

<?php

use Illuminate\Database\Seeder;

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

3. 填充數據

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命令建立模擬數據

4.總結

這樣就能夠生成模擬數據啦,是否是很簡單呢~~~ 若是有幫助到你,給個讚唄!

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

相關文章
相關標籤/搜索