Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to join three table by laravel eloquent model

Tags:

php

mysql

laravel

I have three table

Articles table

 id  title  body  categories_id  user_id 

Categories table

  id   category_name 

User table

 id  user_name  user_type 

I want to show articles with their category name instead of category_id and user_name instead of user_id I try like these query It is work!

$articles =DB::table('articles')                 ->join('categories', 'articles.id', '=', 'categories.id')                 ->join('users', 'users.id', '=', 'articles.user_id')                 ->select('articles.id','articles.title','articles.body','users.username', 'category.name')                 ->get(); 

But I want to do by Eloquent way. Please, how could I do?

like image 373
Nay Avatar asked Mar 20 '15 11:03

Nay


1 Answers

With Eloquent it's very easy to retrieve relational data. Check out the following example with your scenario in Laravel 5.

We have three models:

  1. Article (belongs to user and category)

  2. Category (has many articles)

  3. User (has many articles)


  1. Article.php
    <?php     namespace App\Models;     use Eloquent;          class Article extends Eloquent {         protected $table = 'articles';              public function user() {             return $this->belongsTo('App\Models\User');         }              public function category() {             return $this->belongsTo('App\Models\Category');         }     } 
  1. Category.php
    <?php     namespace App\Models;          use Eloquent;          class Category extends Eloquent {         protected $table = "categories";              public function articles() {             return $this->hasMany('App\Models\Article');         }     } 
  1. User.php
    <?php     namespace App\Models;     use Eloquent;          class User extends Eloquent {         protected $table = 'users';              public function articles() {             return $this->hasMany('App\Models\Article');         }     } 

You need to understand your database relation and setup in models. The user has many articles. The category has many articles. Articles belong to user and category. Once you set up the relationships in Laravel, it becomes easy to retrieve the related information.

For example, if you want to retrieve an article by using the user and category, you would need to write:

$article = \App\Models\Article::with(['user','category'])->first(); 

and you can use this like so:

//retrieve user name  $article->user->user_name    //retrieve category name  $article->category->category_name 

In another case, you might need to retrieve all the articles within a category or retrieve all of a specific user`s articles. You can write it like this:

$categories = \App\Models\Category::with('articles')->get(); $users = \App\Models\Category::with('users')->get(); 

You can learn more at http://laravel.com/docs/5.0/eloquent

like image 188
Anand Patel Avatar answered Oct 13 '22 23:10

Anand Patel