laravel 使用 Faker 数据填充

导语

作开发的时候,添加测试数据是必不可少的,laravel 内置了很方便的数据填充,下面是实例。php

数据迁移

  1. 先建立数据模型和数据迁移 php artisan make:model Models/FakerUser -m
  2. 只建立几个简单字段,编辑 database/migrations/{now_date}_create_faker_users_table.php 文件
/**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('faker_users', function (Blueprint $table) {
            $table->increments('id');
            $table->char('name', 20)->comment('姓名');
            $table->string('email', 50)->comment('邮箱');
            $table->tinyInteger('age')->comment('年龄');
            $table->char('city', 20)->comment('城市');
            $table->timestamps();
        });

        DB::statement("ALTER TABLE `faker_users` comment'测试用户表'"); // 表注释
    }
  1. 运行数据迁移 php artisan migrate 以后数据表建立完成。

数据填充

  1. 建立数据填充文件 php artisan make:seeder FakerUsersSeeder
  2. 建立完成后,咱们能够在 run() 方法中手动添加几条测试数据。可是好的办法,是使用模型工厂,接下来把注意力转移到模型工厂中;
  3. 建立模型工厂 php artisan make:factory FakerUsersFactory
  4. 在模型工厂中,能够经过 Faker\Generator 来生成测试数据,编辑 database/factories/FakerUsersFactory.php
<?php

use Faker\Generator as Faker;

$factory->define(\App\Models\FakerUser::class, function (Faker $faker) {
    return [
        'name' => $faker->name,
        'email' => $faker->safeEmail,
        'age' => $faker->numberBetween(8, 80),// 数字在 8-80 之间随机
        'city' => $faker->city,
        'created_at' => $faker->dateTimeBetween('-3 year', '-1 year'),// 时间在 三年到一年 之间
        'updated_at' => $faker->dateTimeBetween('-1 year', '-5 month'),// 时间在 一年到五个月之间
    ];
});

由上述代码能够很直白的看出 Faker\Generator 的做用。它能够生成的数据类型有不少,更多的类型能够看下官方文档,虽然是英文的,不过都有示例,简单易懂;html

  1. Faker 生成的数据默认是英文,能够在 config/app.php 中将 faker_locale 设置为 zh_CN
  2. 模型工厂写好了,接下来就是调用。目光回到数据填充文件 database/seeds/FakerUsersSeeder.php,在 run() 方法中以下代码
/**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {
        factory(\App\Models\FakerUser::class)->times(1000)->make()->each(function ($model) {
            // 数据入库
            $model->save();
        });
    }

time() 是生成的次数,make() 方法是建立模型实例,在 each() 方法中将生成的模型实例入库保存。laravel

  1. 最后就是执行数据填充,composer dump-autoload 以后 php artisan db:seed --class=FakerUsersSeeder

测试

好了,看下数据库的数据是否生成正确。看下总数
查看总数git

总数没有问题,随机看十条数据
查看数据github

数据也是正确的。数据库


参考资料:数据填充Laravel 文档-数据库测试Fakerapp

相关文章
相关标签/搜索