How To Use Laravel Eloquent One To Many Relationship

4
447
How To Use Laravel One To Many Relationship

In this chapter, we will learn how to use Laravel Eloquent One To Many Relationship. You can connect a single modal to multiple amounts of the modal. Let’s take an example every article has many comments, a book has many chapters and a country has many states. We will use the country and states throughout this tutorial. So let’s get started.

# Requirements

# Create Models With Migrations

Go to PHP project directory and use the following command to install Country and State model and migrations.

php artisan make:model Country -m
php artisan make:model State -m

Using -m option will automatically create migration for model in database > migration folder.

In Country model and replace below code.

/* app > Country.php */

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Country extends Model
{
    protected $fillable = ["name"];
}

Likewise, In State model and replace below code.

/* app > State.php */

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class State extends Model
{
    protected $fillable = ["name"];
}

# Create Database Schema In Migrations.

Define schema in countries migration.

/* database > migrations > *_create_countries_table.php */

public function up()
{
    Schema::create('countries', function (Blueprint $table) {
        $table->bigIncrements('id');
        $table->string('name');
        $table->timestamps();
    });
}

Similarly, define schema in states migration.

/* database > migrations > *_create_states_table.php */

public function up()
{
    Schema::create('states', function (Blueprint $table) {
        $table->bigIncrements('id');
        $table->unsignedBigInteger('country_id');
        $table->string('name');       
        $table->timestamps();

        $table->foreign('country_id')->references('id')->on('countries');
    });
}

Now, migrate two tables with following command.

php artisan migrate

# Defining Relationship

Finally, we are ready to define laravel eloquent one to many relationship between Country and State models.

First of all, define states function (take any name you want) with hasMany method in Country Model. Every One To Many relation must have hasMany method connected to his related model.

/* app > Country.php */

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Country extends Model
{
    protected $fillable = ["name"];

    public function states()
    {
        return $this->hasMany('App\State');
    }
}

Similarly, in State model define country function (you can take any name you want) with belongsTo method in it. That is inverse relationship.

/* app > State.php */

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class State extends Model
{
    protected $fillable = ["name"];

    public function country()
    {
        return $this->belongsTo('App\Country');
    }
}

Thats It! You created one to many relationship between Country and State model. You just need to remember hasMany and belongsTo functions defined in models.

# Usage

Suppose if you have country object and you want to find all states of the country then you can use hasMany function defined in Country model.

$country = App\Country::find(1);
$states = $country->states;

foreach($states as $state)
{
	echo $state->name;
}

Similarly, If you want to find country from state object then you can use belongsTo function defined in State model.

$state = App\State::find(1);
$state->country->name;

Please follow following tutorials to know more about Laravel Relationships

Previous articleHow To Use Bitly Url Shortener In Laravel?
Next articleHow To Use Laravel Eager Loading
Welcome to the world of web development, where technology and creativity come together to bring ideas to life. My name is Keyur Gadher, and as a web development blogger, I am here to share my knowledge and experience with you. From front-end web development to back-end programming, I will provide you with valuable tips, tricks, and techniques to help you create beautiful and functional websites that are tailored to your specific needs. Whether you're a beginner or a seasoned pro, I am here to help you take your web development skills to the next level. Join me today and let's start coding!

4 COMMENTS

LEAVE A REPLY

Please enter your comment!
Please enter your name here