Skip to content

[Laravel] A smart way of seeding tables

Notifications You must be signed in to change notification settings

diegovilette/gardener

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

91 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Smart seeder for Laravel

Seeding as it is currently done in Laravel is intended only for dev builds, but what if you're iteratively creating your database and want to constantly flush it and repopulate it during development? What if you want to seed a production database with different data from what you use in development? What if you want to seed a table you've added to a database that is currently in production with new data?

Features

  • Allows you to seed databases in different environments with different values.
  • Allows you to "version" seeds the same way that Laravel currently handles migrations. Running php artisan seed will only run seeds that haven't already been run.
  • Prompts you if your database is in production.
  • Allows you to run multiple seeds of the same model/table
  • Overrides Laravel's seeding commands. SmartSeeder will fire when you run
    php artisan db:seed
    
    or
    php artisan migrate:refresh --seed
    
  • You can run a single seed file with the --file option. php artisan seed:run --file=seed_2015_05_27_030017_UserSeeder

Use

When you install SmartSeeder, various artisan commands are made available to you which use the same methodology you're used to using with Migrations.

seed:runRuns all the seeds in the smartSeeds directory that haven't been run yet.
seed:makeMakes a new seed class in the environment you specify.
seed:rollbackRollback doesn't undo seeding (which would be impossible with an auto-incrementing primary key). It just allows you to re-run the last batch of seeds.
seed:resetResets all the seeds.
seed:refreshResets and re-runs all seeds.
seed:installYou don't have to use this... it will be run automatically when you call "seed"

Installation

  • Add require: "gizburdt/gardener": "5.2.*" to your composer.json and run an update to bring it in (or run composer require jlapp/smartseeder).
  • Add Jlapp\SmartSeeder\SmartSeederServiceProvider::class to your providers array in app/config/app.php
  • Run php artisan vendor:publish to push config files to your config folder if you want to override the name of the seeds folder or the name of the table where seeds are stored

About

[Laravel] A smart way of seeding tables

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%