美文网首页
laravel 使用 Faker 数据填充

laravel 使用 Faker 数据填充

作者: haoyq | 来源:发表于2019-01-18 11:48 被阅读0次

    导语

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

    数据迁移

    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 的作用。它可以生成的数据类型有很多,更多的类型可以看下官方文档,虽然是英文的,不过都有示例,简单易懂;

    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() 方法中将生成的模型实例入库保存。

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

    测试

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


    查看总数

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


    查看数据

    数据也是正确的。


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

    相关文章

      网友评论

          本文标题:laravel 使用 Faker 数据填充

          本文链接:https://www.haomeiwen.com/subject/eotmdqtx.html