Table of Contents
4.1 基本用法
4.2 单独生成填充器并使用
4.3运行填充器
4.4 更快的批量生产数据Model factory
Home Backend Development PHP Tutorial 【laravel5.1-0.0.6】Seeder自动填充测试数据

【laravel5.1-0.0.6】Seeder自动填充测试数据

Jun 23, 2016 pm 01:24 PM

简书:http://www.jianshu.com/users/85c8826ce087/latest_articles

1.Seeder是什么?
  • 是个数据填充器工具;

  • laravel自带database/seeds/DatabaseSeeder.php类;

  • 文件将通过命令生成在 database/seeds/下;

2.Seeder什么用?
  • 自动生成批量测试数据;

  • 通过表的迁移后可自动导入一系列数据,便于协作开发;

3.Seeder原代码
<?phpuse 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);           Model::reguard();        }}
Copy after login
  • DatabaseSeeder类中只包含run方法,将在数据生成命令运行时被调用;

  • 3种数据库操作方法在run()方法中均可使用

  • 无返回值

4.Seeder用法

4.1 基本用法

  • 在database/seeds/DatabaseSeeder.php中填写内容用来填充数据;

  • run()方法中添加内容将填充到articles表中数据内容(使用SQL语句):

    public function run()    {       DB::insert('insert into                    articles(title, content,created_at,updated_at)                            values (?, ?,?,?)',                      ['article-title2','article-content2',                  \Carbon\Carbon::now(),\Carbon\Carbon::now()]                  );    }
Copy after login
  • 接着在目录下 运行命令 php artisan db:seed 如果没提示,那就去数据库表中看看吧,一条记录就这样生成了;

  • 要同时生成多条记录可以加入多条语句然后同样运行
    php artisan db:seed;

  • 用到了一个简单的时间包: Carbon值得推荐使用;

4.2 单独生成填充器并使用

  • 新建一个填充类:

php artisan make:seeder ArticleTableSeeder
Copy after login
  • 将之前写在database/seeds/DatabaseSeeder类中的插入语句剪切到database/seeds/ArticleTableSeeder类的run()方法中;

  • 在DatabaseSeeder类run()方法中,使用call方法获取要运行的填充器类:

public function run(){    $this->call(ArticleTableSeeder::class);}
Copy after login
  • 这样把每个表要填充的数据都能分开用,真是很不错的;

  • 运行填充器:

4.3运行填充器

  • 命令:

php artisan db:seed
Copy after login
  • 单独运行某个填充器要加上--class=ArticleTableSeeder

php artisan db:seed --class=ArticleTableSeeder
Copy after login
  • 回滚并重新运行数据迁移

php artisan migrate:refresh --seed
Copy after login

4.4 更快的批量生产数据Model factory

  • 模型工厂值得再详细说明 :
    http://laravelacademy.org/post/238.html#model-factories

学习Laravel学院笔记: http://laravelacademy.org/post/133.html

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Working with Flash Session Data in Laravel Working with Flash Session Data in Laravel Mar 12, 2025 pm 05:08 PM

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

cURL in PHP: How to Use the PHP cURL Extension in REST APIs cURL in PHP: How to Use the PHP cURL Extension in REST APIs Mar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Simplified HTTP Response Mocking in Laravel Tests Simplified HTTP Response Mocking in Laravel Tests Mar 12, 2025 pm 05:09 PM

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 Best PHP Chat Scripts on CodeCanyon 12 Best PHP Chat Scripts on CodeCanyon Mar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Explain the concept of late static binding in PHP. Explain the concept of late static binding in PHP. Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

PHP Logging: Best Practices for PHP Log Analysis PHP Logging: Best Practices for PHP Log Analysis Mar 10, 2025 pm 02:32 PM

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

HTTP Method Verification in Laravel HTTP Method Verification in Laravel Mar 05, 2025 pm 04:14 PM

Laravel simplifies HTTP verb handling in incoming requests, streamlining diverse operation management within your applications. The method() and isMethod() methods efficiently identify and validate request types. This feature is crucial for building

Discover File Downloads in Laravel with Storage::download Discover File Downloads in Laravel with Storage::download Mar 06, 2025 am 02:22 AM

The Storage::download method of the Laravel framework provides a concise API for safely handling file downloads while managing abstractions of file storage. Here is an example of using Storage::download() in the example controller:

See all articles