Package Data | |
---|---|
Maintainer Username: | triasrahman |
Maintainer Contact: | contact@triasrahman.com (Trias Nur Rahman) |
Package Create Date: | 2015-09-05 |
Package Last Update: | 2015-09-06 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-15 15:23:54 |
Package Statistics | |
---|---|
Total Downloads: | 319 |
Monthly Downloads: | 2 |
Daily Downloads: | 1 |
Total Stars: | 12 |
Total Watchers: | 3 |
Total Forks: | 1 |
Total Open Issues: | 2 |
This is a package to make your development workflow efficient by seeding the database from JSON files quickly.
Require this package with composer:
composer require triasrahman/json-seeder
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.
<?php
use Illuminate\Database\Seeder;
use Triasrahman\JSONSeeder\JSONSeeder;
class YourTableSeeder extends Seeder
{
use JSONSeeder;
...
And then on run()
method, just call $this->JSONSeed($tableName, $className, [$realtions])
. For example:
CountriesTableSeeder.php
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
$this->JSONSeed('countries', '\App\Country');
}
}
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.
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:
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": "johndoe@mail.com"
},
"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.
$this->JSONSeed('posts', '\App\Post', [
// has many
'picture' => [
'table' => 'pictures', // Table name (optional). If blank, it will pluralize from the name
'class' => '\App\Picture', // Define the related class
'foreign_key' => 'post_id', // Define the foreign key in related class
'flush' => true, // If true, it will flush the related table (optional, default: false)
],
// many to many
'categories' =>
'table' => 'categories', // Table name (optional). If blank, it will pluralize from the name
'class' => '\App\Category', // Define the related class
'flush' => true, // If true, it will flush the related table (optional, default: false)
'many_to_many' => true, // If this relation is many to many, set it true
],
// belongs to
'author' => [
'table' => 'users', // Table name (optional). If blank, it will pluralize from the name
'class' => '\App\User', // Define the related class
'local_key' => 'user_id', // Define the local key in related class
'flush' => true, // If true, it will flush the related table (optional, default: false)
],
]);
So easy right? Just try it now!
Laravel JSON Seeder is licensed under the MIT License.
Copyright 2015 Trias Nur Rahman