Download the PHP package triasrahman/jsonseeder without Composer
On this page you can find all versions of the php package triasrahman/jsonseeder. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package jsonseeder
Quick and efficient seeding database from JSON files for Laravel
This is a package to make your development workflow efficient by seeding the database from JSON files quickly.
Installation
Require this package with composer:
Usage
Prepare your JSON files for every table you want to seed using format {table-name}.json
, for example:
countries.json
[
{name: 'Afghanistan', code: 'AF'},
{name: 'Åland Islands', code: 'AX'},
{name: 'Albania', code: 'AL'},
{name: 'Algeria', code: 'DZ'},
{name: 'American Samoa', code: 'AS'},
{name: 'AndorrA', code: 'AD'},
{name: 'Angola', code: 'AO'},
{name: 'Anguilla', code: 'AI'},
{name: 'Antarctica', code: 'AQ'},
{name: 'Antigua and Barbuda', code: 'AG'},
{name: 'Argentina', code: 'AR'},
{name: 'Armenia', code: 'AM'},
{name: 'Aruba', code: 'AW'},
{name: 'Australia', code: 'AU'},
{name: 'Austria', code: 'AT'},
{name: 'Azerbaijan', code: 'AZ'},
{name: 'Bahamas', code: 'BS'},
...
]
Save them into storage/database
, for example:
/storage
/database
- users.json
- cities.json
- countries.json
- products.json
- posts.json
On your Seeder class (located at database/seeds/
), append use Triasrahman\JSONSeeder\JSONSeeder
namespace and use JSONSeeder
trait inside the class.
And then on run()
method, just call $this->JSONSeed($tableName, $className, [$realtions])
. For example:
CountriesTableSeeder.php
NOTE: You can run this on DatabaseSeeder.php
too!
Just run on console php artisan db:seed
, and viola!
See the Official Laravel Documentation for more database seeding usage.
Complex JSON Structure
We really understand that Laravel has powerful ORM named Eloquent. We want it make easier for you on this package. Yes, you can import your relational model here! It currently supports:
- One to One
- One to Many
- Many to Many
- Polymorphic (Coming Soon)
For example when we have a blog website, we wanna seed the posts table. You can easily set the JSON file like this. posts.json
[{
"title": "Hello World!",
"content": "This is my new blog.",
"year": 2014,
"categories": [
{
"name": "Hello",
"description": "This is a category"
},
{
"name": "World",
"description": "This is a category"
}
],
"author": {
"name": "John Doe",
"email": "[email protected]"
},
"pictures": [
{
"title": "Picture 1",
"path": "uploads/picture-1.jpg"
},
{
"title": "Picture 2",
"path": "uploads/picture-2.jpg"
}
],
"status": "published"
},
...
]
After that you can run using following options.
So easy right? Just try it now!
License
Laravel JSON Seeder is licensed under the MIT License.
Copyright 2015 Trias Nur Rahman