导语
做开发的时候,添加测试数据是必不可少的,laravel 内置了很方便的数据填充,下面是实例。
注意:laravel5框架中已经内置了faker组建,不用安装
数据迁移
先创建数据模型和数据迁移 php artisan make:model Models/FakerUser -m;
只创建几个简单字段,编辑 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'测试用户表'"); // 表注释
}
运行数据迁移 php artisan migrate
之后数据表创建完成。
数据填充
php artisan make:seeder FakerUsersSeeder;
run()
方法中手动添加几条测试数据。但是好的办法,是使用模型工厂,接下来把注意力转移到模型工厂中;php artisan make:factory 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 的作用。它可以生成的数据类型有很多,更多的类型可以看下官方文档,虽然是英文的,不过都有示例,简单易懂;
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() 方法中将生成的模型实例入库保存。
composer dump-autoload
之后 php artisan db:seed --class=FakerUsersSeeder
测试
好了,看下数据库的数据是否生成正确。看下总数
总数没有问题,随机看十条数据
数据也是正确的。