1 生成一个seeder文件

你可以通过 make:seeder artisan命令来生成一个 Seeder。所有通过框架生成的 Seeder 都将被放置在 database/seeds 路径:
php artisan make:seeder StudentsTableSeeder
在 seeder 类里只有一个默认方法:run。
我们可以在这个run方法中给数据库添加任何数据(在这里我们可以使用查询构造器或者Eloquent模型工厂)
我们给run方法添加如下内容
<?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 单独调用

运行命令,调用StudentsTableSeeder类 php artisan db:seed --class=StudentsTableSeeder
我们可以发现数据表中新插入了一条数据
这里要注意一个问题,因为我设计数据库的时候增加了created_at和updated_at字段,使用查询构造器并不能自动更新这两个字段

3 批量调用

Laravle 默认为你定义了一个 DatabaseSeeder 类。你可以在这个类中使用 call 方法来运行多个其它的 seed 类,以借此控制数据填充的顺序,并且可以实现批量调用。
我们将我们生成的StudentsTableSeeder类加入到 run方法中
<?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();
}
}
运行命令,调用DatabaseSeeder类
php artisan db:seed
我们同样可以发现数据表中多了一条数据
 

补充:模型工厂

 
我们刚才在run方法中使用的时候查询构造器,我们还可以使用Eloquent模型工厂
学习如何定义你的工厂,一旦工厂被定义(位于database/fatories文件夹下),就能使用 factory 这个辅助函数来添加数据到数据库。
 
涉及到两部分:
1>创建模型工厂,并调用
2>构造数据的时候可以使用 'Faker' 类,专门生成随机数据,可查看 'https://github.com/fzaninotto/Faker'
 

1 模型工厂示例

先查看下应用程序的 database/factories/ModelFactory.php 文件。此文件包含一个现成的工厂定义:
$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),
];
});
以上是对User 用户模型的定义
App\User::class 对应的就是你的模型位置,我自己在app目录下创建了Models文件夹用于存放各种模型,所以我这里要改成 App\Models\User::class
 
闭包内为工厂的定义,你可以返回模型中所有属性的默认测试值。在该闭包内会接收到 Faker PHP 函数库的实例,它可以让你很方便的生成各种随机数据以进行测试。

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]);
});
3 使用模型工厂
1> make()创建模型但不将其保存到数据库:  
       $user = factory(App\User::class)->make();    
2> 如果你想要覆盖模型的一些默认值,可以传递数组值到make方法。只有指定值被替换,其他数据保持不变:  
$user = factory(App\User::class)->make([  
'name' => 'dongxuemin'       // 会将生成的name替换为 'dongxuemin'  
]);  
3> 创建多个模型集合:  
$users = factory(App\User::class, 3)->make();  
4> 创建给定类型模型:  
$user = factory(App\User::class, 'admin')->make();  
5> 创建多个给定类型的集合:  
$user = factory(App\User::class, 'admin', 3)->make();  
6> 保存模型至数据库
可使用 create 方法来创建模型实例(相当于创建和保存两步)
$users = factory(App\Models\User::class)->create();
或者通过make方法得到模型实例后,使用 Eloquent 的 save 方法来将它们保存至数据库
$users = factory(App\Models\User::class)->make();
$users->save();
7>当使用 make 或 create 方法创建多个模型时,它会返回一个 Eloquent 集合实例,让你能够使用集合所提供的便利函数,像是 each
8>当模型中(app\Models文件夹下的model文件中)定义了关联关系时候,我们可以增加关联至模型
//使用基本的用户工厂创建一个用户,并使用基本的用户账号工厂
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());
});
分析:可以分为两部分理解,首先,在 factory(App\User::class, 2)->create() 这句中写明了,我们需要构建 User 类,在数据库中创建两个用户。然后,用 collection 的 each 方法为每个被创建的用户建立关联的问题数据,并且此部分使用了我们前面定义的不同工厂
 

laravel5.2总结--数据填充的更多相关文章

  1. Laravel5.1学习笔记18 数据库4 数据填充

    简介 编写数据填充类 使用模型工厂类 调用额外填充类 执行填充 #简介 Laravel includes a simple method of seeding your database with t ...

  2. Laravel 实践之路: 数据库迁移与数据填充

    数据库迁移实际上就是对数据库库表的结构变化做版本控制,之前对数据库库表结构做修改的方式比较原始,比如说对某张库表新增了一个字段,都是直接在库表中执行alter table xxx add .. 的方式 ...

  3. .net dataGridView当鼠标经过时当前行背景色变色;然后【给GridView增加单击行事件,并获取单击行的数据填充到页面中的控件中】

    1.首先在前台dataGridview属性中增加onRowDataBound属性事件 2.然后在后台Observing_RowDataBound事件中增加代码 protected void Obser ...

  4. ECharts SSH+JQueryAjax+Json+JSP将数据库中数据填充到ECharts中

    本文引用自:http://blog.csdn.net/ArcticFoxHan/article/details/38071641   1.导入包,搭建SSH框架 导入Jquery的JS包,<sc ...

  5. Laravel-高级篇-Auth-数据迁移-数据填充

    (慕课网_轻松学会Laravel-高级篇_天秤vs永恒老师_http://www.imooc.com/learn/702) 一.生成Auth所需文件 在Artisan控制台输入以下命令 php art ...

  6. highcharts柱状图和饼图的数据填充

    1.其实数据填充很简单,它们就是json的格式,然后后台按照这种格式去套数据发给前端:前端再做一下连接处理等就行了. $('#program_statistics_bar').highcharts({ ...

  7. Laravel 5.2 教程 - 数据填充

    一.简介 Laravel提供的填充类(seed),可以让大家很容易的实现填充测试数据到数据库.所有的填充类都位于database/seeds目录.填充类的类名完全由你自定义,但最好还是遵循一定的规则, ...

  8. CVPixelBuffer的创建 数据填充 以及数据读取

    CVPixelBuffer的创建数据填充以及数据读取 CVPixelBuffer 在音视频编解码以及图像处理过程中应用广泛,有时需要读取内部数据,很少的时候需要自行创建并填充数据,下面简单叙述. 创建 ...

  9. 将Json数据 填充到 实例类 的函数

    /// <summary> /// 将Json数据 填充到 实例类 /// </summary> /// <typeparam name="T"> ...

随机推荐

  1. ABAP WRITE

    1.空行 WRITE /. 2.AS CHECKBOX VALUE 'X', check2 VALUE ' '. START-OF-SELECTION. WRITE: / check1 AS CHEC ...

  2. 安装windows phone 7

    本机环境win7 32位旗舰版,本来是4G内存的  系统只能读出2.9G,vs2010中文旗舰版,想搭建windows phone环境学习wp手机开发.安装完了之后明显感觉机器慢了些. ①:安装Mic ...

  3. hihoCoder hiho一下 第二周 #1014 : Trie树(Trie树基本应用)

    思路: 完全看题目中的介绍就行了.还有里面的input写道:不保证是英文单词,也有可能是火星文单词哦.比赛结束后的提交是不用考虑26个字母之外的,都会AC,如果考虑128种可能的话,爆了内存.步骤就是 ...

  4. ELF文件的格式和加载过程

    http://blog.csdn.net/lingfong_cool/article/details/7832896 (一) ELF 文件的格式       ELF 文件类型 (1) 可重定位文件(  ...

  5. 【POJ2774】Long Long Message(后缀数组求Height数组)

    点此看题面 大致题意: 求两个字符串中最长公共子串的长度. 关于后缀数组 关于\(Height\)数组的概念以及如何用后缀数组求\(Height\)数组详见这篇博客:后缀数组入门(二)--Height ...

  6. 在ListView控件中实现修改功能

    实现效果: 知识运用: ListView控件的LabelEdit属性 //指示用户是否可以编辑控件中数据项的标签 public bool LabelEdit{get;set;} 实现代码: priva ...

  7. Rhadoop安装

    1.ubuntu,hadoop,R,jdk安装好 2.下载Rhadoop项目的的三个包,rmr,hdfs,rHBase存放到Downloads/R. 3.切换到root 4.安装依赖的库 ~R CMD ...

  8. 复选框(checkbox)、多选框

    1.需求分析 可同时选中多个选项,实现全选.全不选.反选等功能. 2.技术分析 基础的HTML.CSS.JavaScript. 3.详细分析 3.1 HTML部分 图示是一个列表加底部一段文字说明,列 ...

  9. react 的虚拟dom

    前端优化的主要方面就是减少页面的DOM操作,减少重排和重绘,React在这方面做了优化,采用了所谓的虚拟DOM,其实我们平时也会遇到虚拟DOM,只是你没有注意罢了,请听我娓娓道来.  所谓的虚拟DOM ...

  10. java实现单链表归并算法

    public class LinkMergeSort {static int number=0;public static void main(String[] args) {int[] a = {1 ...