laravel5.2总结--数据填充
1 生成一个seeder文件
<?php use Illuminate\Database\Seeder;
use DB;
use App\Models\Student; class StudentsTableSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
//使用基本查询构造器
DB::table('students')->insert([
'name' => str_random(10),
]);
//可以使用orm模型
Student::insert([
'name' => str_random(10),
]);
//还可以使用模型工厂
}
}
2 单独调用
3 批量调用
<?php use Illuminate\Database\Seeder;
use Illuminate\Database\Eloquent\Model; class DatabaseSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard(); // $this->call(UserTableSeeder::class);
//这里我们可以调用更多生成的填充数据类,便于管理
$this->call(StudentsTableSeeder::class);
Model::reguard();
}
}
补充:模型工厂
1 模型工厂示例
$factory->define(App\User::class, function (Faker\Generator $faker) {
return [
'name' => $faker->name,
'email' => $faker->email,
'password' => bcrypt(str_random(10)),
'remember_token' => str_random(10),
];
});
2 创建模型工厂
//示例 对应User模型
$factory->define(App\Models\User::class, function (Faker\Generator $faker) {
return [
'name' => $faker->name, //使用faker生成数据
'email' => $faker->safeEmail,
'password' => bcrypt(str_random(10)), //不使用faker生成数据
'remember_token' => str_random(10),
];
}); //创建一个UserAccount模型的工厂
$factory->define(App\Models\UserAccount::class, function (Faker\Generator $faker) {
return [
'qq' => rand(10000,999999999999),
'weixin' => $faker->userName,
'weibo' => $faker->word,
];
}); //同一个UserAccount模型,不同的工厂
$factory->defineAs(App\Models\UserAccount::class,'mark', function (Faker\Generator $faker) {
return [
'qq' => rand(10000,999999999999),
'weixin' => $faker->userName,
'weibo' => $faker->word,
'mark' => 1,
];
}); //同一个UserAccount模型,不同的工厂,第二种写法
//使用raw方法获取基本属性而不用重复基本用户工厂中的所有属性,获取这些属性后,只需将你要求的额外值增补进去即可
$factory->defineAs(App\Models\UserAccount::class,'mark2', function (Faker\Generator $faker) use($factory) {
// 注意向闭包函数传递变量使用use方法
$user_account = $factory->raw(App\Models\UserAccount::class);
return array_merge($user_account, ['mark' => 1]);
});
//使用基本的用户工厂创建一个用户,并使用基本的用户账号工厂
factory(App\Models\User::class)->create()->each(function($u) {
$u->account()->save(factory(App\Models\UserAccount::class)->make());
});
//使用基本的用户工厂创建2个用户,并使用基本的用户账号工厂
factory(App\Models\User::class, 2)->create()->each(function($u) {
$u->account()->save(factory(App\Models\UserAccount::class)->make());
});
//使用基本的用户工厂创建2个用户,并使用 "mark" 用户账号工厂
factory(App\Models\User::class, 2)->create()->each(function($u) {
$u->account()->save(factory(App\Models\UserAccount::class,'mark')->make());
});
//使用基本的用户工厂创建2个用户,并使用 "mark2" 用户账号工厂
factory(App\Models\User::class, 2)->create()->each(function($u) {
$u->account()->save(factory(App\Models\UserAccount::class,'mark2')->make());
});
laravel5.2总结--数据填充的更多相关文章
- Laravel5.1学习笔记18 数据库4 数据填充
简介 编写数据填充类 使用模型工厂类 调用额外填充类 执行填充 #简介 Laravel includes a simple method of seeding your database with t ...
- Laravel 实践之路: 数据库迁移与数据填充
数据库迁移实际上就是对数据库库表的结构变化做版本控制,之前对数据库库表结构做修改的方式比较原始,比如说对某张库表新增了一个字段,都是直接在库表中执行alter table xxx add .. 的方式 ...
- .net dataGridView当鼠标经过时当前行背景色变色;然后【给GridView增加单击行事件,并获取单击行的数据填充到页面中的控件中】
1.首先在前台dataGridview属性中增加onRowDataBound属性事件 2.然后在后台Observing_RowDataBound事件中增加代码 protected void Obser ...
- ECharts SSH+JQueryAjax+Json+JSP将数据库中数据填充到ECharts中
本文引用自:http://blog.csdn.net/ArcticFoxHan/article/details/38071641 1.导入包,搭建SSH框架 导入Jquery的JS包,<sc ...
- Laravel-高级篇-Auth-数据迁移-数据填充
(慕课网_轻松学会Laravel-高级篇_天秤vs永恒老师_http://www.imooc.com/learn/702) 一.生成Auth所需文件 在Artisan控制台输入以下命令 php art ...
- highcharts柱状图和饼图的数据填充
1.其实数据填充很简单,它们就是json的格式,然后后台按照这种格式去套数据发给前端:前端再做一下连接处理等就行了. $('#program_statistics_bar').highcharts({ ...
- Laravel 5.2 教程 - 数据填充
一.简介 Laravel提供的填充类(seed),可以让大家很容易的实现填充测试数据到数据库.所有的填充类都位于database/seeds目录.填充类的类名完全由你自定义,但最好还是遵循一定的规则, ...
- CVPixelBuffer的创建 数据填充 以及数据读取
CVPixelBuffer的创建数据填充以及数据读取 CVPixelBuffer 在音视频编解码以及图像处理过程中应用广泛,有时需要读取内部数据,很少的时候需要自行创建并填充数据,下面简单叙述. 创建 ...
- 将Json数据 填充到 实例类 的函数
/// <summary> /// 将Json数据 填充到 实例类 /// </summary> /// <typeparam name="T"> ...
随机推荐
- ArrayList与Vector区别
ArrayList与Vector区别表 ArrayList Vector 1.实现原理:采用动态对象数组实现,默认构造方法创建了一个空数组 1.实现原理:采用动态数组对象实现,默认构造方法创建了一个大 ...
- Every ending is just a new beginning.
Every ending is just a new beginning.每次结束都是新的开始.
- addin修改启动路径
- zabbix-3.4 触发器
3 触发器 概述 触发器是"评估"由项目采集的数据并表示当前系统状况的逻辑表达式. 当监控项用于采集系统的数据时,始终遵循这些数据是非常不切合实际的,因为这些数据始终在等待一个令人 ...
- FreeBSD 安裝 wget
cd /usr/ports/ftp/wgetmake install clean pkg_add -r wget就可以把wget安装上去了
- 腾讯云服务器CVM购买详细过程 选择我们需要的腾讯云服务器
腾讯云服务商有云服务器.云数据库.CDN.云存储等产品,其中较多的用户会选择腾讯云服务器,因为用途比较广泛,比如用来软件的运行以及网站建设,如今一般都是用云服务器,而不是用虚拟主机,毕竟虚拟主机的性价 ...
- linux 命令——9 touch (转)
linux的touch命令不常用,一般在使用make的时候可能会用到,用来修改文件时间戳,或者新建一个不存在的文件. 1.命令格式: touch [选项]... 文件... 2.命令参数: -a ...
- 汶川大地震中的SAP成都研究院
5·12汶川地震,发生于北京时间(UTC+8)2008年5月12日(星期一)14时28分04秒,此次地震的面波震级 里氏震级达8.0Ms.矩震级达8.3Mw,地震烈度达到11度.地震波及大半个中国及亚 ...
- 一个普通 iOS 码农的几个小项目相关知识点总结
题记:在开发的路途上,有的人走的很深很远,而对于停留在初级阶段的我来说,还要学的.经历的还有很多... list sqlite 数据库中,当把表里的数据都清空时,下次插入的数据的 id 主键不会从 0 ...
- noip模拟赛#23
T1:n个元素的集合.要求取出k个子集,使得k个子集交集为空集.问有多少中取法. =>推了很久...想的是从k等于2的情况推到k等于3的情况....然后k=2推出来了k=3也推出来了...推了挺 ...