Laravel生成测试数据

本文详细介绍如何在Laravel框架中使用Faker工具生成大量测试数据。从数据迁移、模型工厂到数据填充,一步步演示如何快速填充真实感的测试数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Laravel使用Faker数据填充,生成测试数据

做开发的时候,添加测试数据是必不可少的
ps : Faker 是Laravel 自带的功能,不需要下载

1.数据迁移 生成测试表

先创建数据模型和数据迁移 php artisan make:model Models/FakerUser -m

在/database/migrations 找到对应日期生成的迁移文件。
如:2020_04_01_031822_create_faker_users_table.php

添加测试表的字段

 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();
	 });
 }

运行数据迁移 php artisan migrate 之后数据表创建完成。
有报错请自行百度,这里不做过多解释。

2. 填充数据

  • 创建数据填充文件 php artisan make:seeder FakerUsersSeeder
  • 创建完成后,我们可以在 run() 方法中手动添加几条测试数据。但是好的办法,是使用模型工厂,接下来把注意力转移到模型工厂中;
  • 创建模型工厂 php artisan make:factory FakerUsersFactory
  • 在模型工厂中,可以通过 Faker\Generator 来生成测试数据,编辑 database/factories/FakerUsersFactory.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 的作用。它可以生成的数据类型有很多,更多的类型可以看下官方文档,虽然是英文的,不过都有示例,简单易懂;

ps: Faker 生成的数据默认是英文,可以在 config/app.php 中将 faker_locale 设置为zh_CN

模型工厂写好了,接下来就是调用。目光回到数据填充文件 database/seeds/FakerUsersSeeder.php,在 run() 方法中如下代码

public function run()
 {
	 factory(\App\Models\FakerUser::class)->times(1000)->make()->each(function ($model) {
	  // 数据入库
	  $model->save();
	 });
 }

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

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

测试

自己执行query

select count(*) from faker_users
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值