laravel使用Faker数据填充的实现方法
时间:2022-07-27
本文章向大家介绍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;
- 在模型工厂中,可以通过 FakerGenerator 来生成测试数据,编辑 database/factories/FakerUsersFactory.php
<?php
use FakerGenerator as Faker;
$factory- define(AppModelsFakerUser::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'),// 时间在 一年到五个月之间
];
});
由上述代码可以很直白的看出 FakerGenerator 的作用。它可以生成的数据类型有很多,更多的类型可以看下官方文档,虽然是英文的,不过都有示例,简单易懂;
- Faker 生成的数据默认是英文,可以在 config/app.php 中将 faker_locale 设置为 zh_CN;
- 模型工厂写好了,接下来就是调用。目光回到数据填充文件 database/seeds/FakerUsersSeeder.php,在
run()
方法中如下代码
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
factory(AppModelsFakerUser::class)- times(1000)- make()- each(function ($model) {
// 数据入库
$model- save();
});
}
time()
是生成的次数,make()
方法是创建模型实例,在 each() 方法中将生成的模型实例入库保存。
- 最后就是执行数据填充,
composer dump-autoload
之后php artisan db:seed --class=FakerUsersSeeder
测试
好了,看下数据库的数据是否生成正确。看下总数
总数没有问题,随机看十条数据
数据也是正确的。
- 腾讯AI让二子,柯洁还是输了
- AI创业者的“英雄联盟”,腾讯AI加速器二期项目招募开启
- PyTorch发布一周年:盘点社区和工程大事件,后来者居上态势已显?
- 2018年AI如何发展?普华永道做出了8点预测 | 报告下载
- 不正之风!机器学习论文里都有哪四大投机取巧的写作手法?
- 前端写一个月的原生 Android 是怎样一种体验?
- 给人挖矿还不自知 电脑已变黑客肉鸡
- 反序列化漏洞屡被黑客利用,危害巨大,代码怎样写才安全?
- Mifa 主题微信编辑器
- Mifa GitHub Pages 主题
- Mifa Design:一个服务于 Markdown 的设计体系
- 未来机器人大脑将获取互联网知识自我学习
- 【架构拾集】: Android 移动应用架构设计
- Dore 混合应用框架 —— 基于 React Native 的混合应用迁移方案
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- 防盗链的原理以及实现
- Python如何根据日期判断周几
- http常见状态码
- golang time相关总结
- [白话解析] 深入浅出熵的概念 & 决策树之ID3算法
- [白话解析] 深入浅出边缘计算
- 变废为宝 | 旧电脑变云数据中心 | Esxi 配置
- 【Java面试总结】Java基础(上篇)
- Esxi安装LEDE(OpenWrt) | 旧电脑变庞路由
- [白话解析] 深入浅出贝叶斯定理
- LEDE(OpenWrt)安装openclash |旁路由技巧 | 配置网络流量全部通过旁路由
- [白话解析] 深入浅出朴素贝叶斯模型原理及应用
- 【Java面试总结】Java基础(下篇)
- 使用现代化的脚本进行 ArcGIS JS API 开发
- TextField suffixIcon点击时TextField 选中弹出键盘<Flutter Bug篇>