Upgrade & Secure Your Future with DevOps, SRE, DevSecOps, MLOps!

We spend hours scrolling social media and waste money on things we forget, but won’t spend 30 minutes a day earning certifications that can change our lives.
Master in DevOps, SRE, DevSecOps & MLOps by DevOps School!

Learn from Guru Rajesh Kumar and double your salary in just one year.


Get Started Now!

Laravel : A Comprehensive Guide of Seeders

What are Laravel Seeders?

Laravel Seeders are part of Laravel’s Database Seeder functionality, allowing developers to insert sample or default data into their database tables. This is particularly useful for initializing a fresh database with data necessary for testing or setting up default values in production.

How Laravel Seeders Work:

Seeder Classes:

In Laravel, seeders are organized into seeder classes. Each seeder class typically corresponds to a specific database table, and developers can create multiple seeders to populate various tables with different sets of data.

Defining Seed Data:

Within a seeder class, developers use the run method to define the data they want to insert into the associated table. This can include hardcoded values or dynamically generated data using Faker, Laravel’s built-in fake data generator.

Generate a Seeder Class

Use the make:seeder Artisan command to generate a new seeder class. Replace ExampleTableSeeder with the desired name for your seeder and ModelName with the name of the Eloquent model associated with the table:

php artisan make:seeder ExampleTableSeeder

Define Seeder Data

Open the generated seeder class (located in the database/seeders directory) and define the data you want to insert into the associated table within the run method. You can use Laravel’s query builder or Eloquent methods to interact with the database.

For example:

use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB;

class ExampleTableSeeder extends Seeder
{
    public function run()
    {
        DB::table('example_table')->insert([
            'column1' => 'value1',
            'column2' => 'value2',
            // Additional columns and data
        ]);
    }
}

Run the Seeder

To execute the seeder and insert the defined data into the database, use the db:seed Artisan command. You can specify the seeder class you want to run:

php artisan db:seed --class=ExampleTableSeeder

Run All Seeders (Optional)

If you have multiple seeders and want to run all of them at once, you can use the following Artisan command:

php artisan db:seed

Rollback Seeders (Optional)

To rollback the last batch of seeders and remove the seeded data from the database, you can use the --reverse option:

php artisan db:seed --class=ExampleTableSeeder --reverse

Related Posts

How to Generate a GitHub OAuth Token with Read/Write Permissions for Private Repositories

When working with GitHub, you may need to interact with private repositories. For that, GitHub uses OAuth tokens to authenticate and authorize your access to these repositories….

Laravel Error: Target class [DatabaseSeeder] does not exist – Solved for Laravel 10+

If you’re working with Laravel 10+ and run into the frustrating error: …you’re not alone. This is a common issue developers face, especially when upgrading from older…

JWT (JSON Web Token) vs OAuth 2.0

Both JWT and OAuth 2.0 are used for managing authentication and authorization, but they serve different purposes and work in distinct ways. 1. Purpose: 2. Role: 3….

Exploring and Creating a Proof of Concept (POC) to Upload APK Directly from GitHub Package

Automating the process of uploading an APK (or AAB) to the Google Play Store from GitHub can significantly speed up your CI/CD pipeline. By integrating Google Play’s…

A Detailed Guide to CI/CD with GitHub Actions

Continuous Integration (CI) and Continuous Deployment (CD) are modern software development practices that automate the process of integrating code changes, running tests, and deploying applications. With the…

Step-by-Step Guide for Setting Up Internal Testing in Google Play Console

1. Understanding the Types of Testing Before uploading your Android app for internal testing, it’s essential to know the differences between the testing options available in Google…

0 0 votes
Article Rating
Subscribe
Notify of
guest
0 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
0
Would love your thoughts, please comment.x
()
x