laravel使用Faker数据填充的实现方法


Posted in PHP onApril 12, 2019

导语

做开发的时候,添加测试数据是必不可少的,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 之后数据表创建完成。

数据填充

  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数据填充的实现方法

数据也是正确的。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

PHP 相关文章推荐
PHP 数字左侧自动补0
Mar 31 PHP
php对gzip文件或者字符串解压实例参考
Jul 25 PHP
php设置允许大文件上传示例代码
Mar 10 PHP
函数中使用require_once问题深入探讨 优雅的配置文件定义方法推荐
Jul 02 PHP
jQuery+PHP实现的掷色子抽奖游戏实例
Jan 04 PHP
浅谈PHP中JSON数据操作
Jul 01 PHP
微信公众号开发之语音消息识别php代码
Aug 08 PHP
php微信开发自定义菜单
Aug 27 PHP
PHP API接口必备之输出json格式数据示例代码
Jun 27 PHP
ThinkPHP3.2.3框架实现的空模块、空控制器、空操作,跳转到错误404页面图文详解
Apr 03 PHP
Laravel框架实现多个视图共享相同数据的方法详解
Jul 09 PHP
详解阿里云视频直播PHP-SDK接入教程
Jul 09 PHP
Laravel5.7 Eloquent ORM快速入门详解
Apr 12 #PHP
laravel 数据迁移与 Eloquent ORM的实现方法
Apr 12 #PHP
PHP中的Iterator迭代对象属性详解
Apr 12 #PHP
PHP中str_split()函数的用法讲解
Apr 11 #PHP
PHP远程连接oracle数据库操作实现方法图文详解
Apr 11 #PHP
ThinkPHP5.0框架使用build 自动生成模块操作示例
Apr 11 #PHP
PHP生成随机码的思路与方法实例探索
Apr 11 #PHP
You might like
关于PHP中的Class的几点个人看法
2006/10/09 PHP
解析PHP多种序列化与反序列化的方法
2013/06/06 PHP
php中过滤非法字符的具体实现
2013/10/29 PHP
PHP简单实现断点续传下载的方法
2015/09/25 PHP
Jquery插件编写简明教程
2014/03/25 Javascript
使用时间戳解决ie缓存的问题
2014/08/20 Javascript
jQuery中index()的用法分析
2014/09/05 Javascript
jQuery封装的tab选项卡插件分享
2015/06/16 Javascript
11种ASP连接数据库的方法
2015/09/18 Javascript
JavaScript中Date对象的常用方法示例
2015/10/24 Javascript
JavaScript暂停和继续定时器的实现方法
2016/07/18 Javascript
微信小程序 网络API Websocket详解
2016/11/09 Javascript
详解原生js实现offset方法
2017/06/15 Javascript
vue2项目使用sass的示例代码
2017/06/28 Javascript
解决vue 按钮多次点击重复提交数据问题
2018/05/10 Javascript
js调用设备摄像头的方法
2018/07/19 Javascript
js删除数组中某几项的方法总结
2019/01/16 Javascript
ES6 Iterator遍历器原理,应用场景及相关常用知识拓展详解
2020/02/15 Javascript
vue中使用vue-pdf的方法详解
2020/09/05 Javascript
VUE异步更新DOM - 用$nextTick解决DOM视图的问题
2020/11/06 Javascript
[05:39]2014DOTA2国际邀请赛 DK晋级胜者组专访战队国士无双
2014/07/14 DOTA
python 文件与目录操作
2008/12/24 Python
matplotlib.pyplot画图 图片的二进制流的获取方法
2018/05/24 Python
使用python脚本实现查询火车票工具
2018/07/19 Python
python用post访问restful服务接口的方法
2018/12/07 Python
Python3内置模块pprint让打印比print更美观详解
2019/06/02 Python
搭建pypi私有仓库实现过程详解
2020/11/25 Python
英国品牌男装折扣网站:Brown Bag
2018/03/08 全球购物
北京鼎普科技股份有限公司软件测试面试题
2012/04/07 面试题
学习新党章思想汇报
2014/01/09 职场文书
学历公证委托书
2014/04/09 职场文书
小学生手册家长评语
2014/04/16 职场文书
执行力心得体会范文
2016/01/11 职场文书
总结几个非常实用的Python库
2021/06/26 Python
MySQL慢查询优化解决问题
2022/03/17 MySQL
Golang 1.18 多模块Multi-Module工作区模式的新特性
2022/04/11 Golang