laravel使用Faker数据填充的实现方法
导语
做开发的时候,添加测试数据是必不可少的,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; - 在模型工厂中,可以通过 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 的作用。它可以生成的数据类型有很多,更多的类型可以看下官方文档,虽然是英文的,不过都有示例,简单易懂;
- Faker 生成的数据默认是英文,可以在 config/app.php 中将 faker_locale 设置为 zh_CN;
- 模型工厂写好了,接下来就是调用。目光回到数据填充文件 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() 方法中将生成的模型实例入库保存。
- 最后就是执行数据填充,
composer dump-autoload之后php artisan db:seed --class=FakerUsersSeeder
测试
好了,看下数据库的数据是否生成正确。看下总数

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

数据也是正确的。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
相关文章
Zend Framework教程之Zend_Db_Table_Row用法实例分析
这篇文章主要介绍了Zend Framework教程之Zend_Db_Table_Row用法,详细讲述了Zend_Db_Table_Row的功能,并结合实例形式详细分析了Zend_Db_Table_Row操作数据的相关技巧,需要的朋友可以参考下2016-03-03
PHP CURL或file_get_contents获取网页标题的代码及两者效率的稳定性问题
PHP CURL与file_get_contents函数都可以获取远程服务器上的文件保存到本地,但在性能上面两者完全不在同一个级别,下面通过一个例子给大家介绍PHP CURL或file_get_contents获取网页标题的代码及两者效率的稳定性问题,需要的朋友参考下2015-11-11
PHP register_shutdown_function函数的深入解析
本篇文章是对PHP register_shutdown_function函数进行了详细的分析介绍,需要的朋友参考下2013-06-06
CodeIgniter辅助之第三方类库third_party用法分析
这篇文章主要介绍了CodeIgniter辅助之第三方类库third_party用法,以CI集成Twig模版为例分析了CodeIgniter集成第三方类库的实现步骤与相关技巧,需要的朋友可以参考下2016-01-01
php页面,mysql数据库转utf-8乱码,utf-8编码问题总结
一个网站如果需要国际化,就需要将编码从GB2312转成UTF-8,其中有很多的问题需要注意,如果没有转换彻底,将会有很多的编码问题出现!接下来通过本篇文章给大家分享php页面,mysql数据库转utf-8乱码,utf-8编码问题总结,需要的朋友可以参考下2015-08-08


最新评论