Laravel 9 Left Join Query Example

Websolutionstuff | Mar-31-2022 | Categories : Laravel PHP MySQL

In this article, we will see the laravel 9 left join query example. laravel 9 left join eloquent returns all rows from the left table, even if there are no matches in the right table, The result is NULL from the right side. We will also see query of laravel 9 left join with groupBy(). If you would like to perform a "left join" or "right join" instead of an "inner join", use the leftJoin or rightJoin methods. These methods have the same signature as the join method.

So, let's see examples of left join in laravel 9, laravel 9 join two tables, left join in laravel 9, laravel 9 left join query, laravel 9 left join group by, left join query in MySQL, left join query in PHP, laravel left join subquery, laravel 9 left join query, left join in laravel 9.

For the laravel 9 left join query example we need the first argument passed to the leftJoin method to be the name of the table you need to join to, while the remaining arguments specify the column constraints for the join. Left join query use in laravel 6, laravel 7, laravel 8, laravel 9.



SQL Query :

In this example, we will create users table and countries table. we will add the country_id  foriegn key on the user's table. So, when I get users at that time we will get country name from country_id using left join.

SELECT column_name(s)
FROM table1
LEFT JOIN table2
ON table1.column_name = table2.column_name;



The LEFT JOIN keyword returns all records from the left table (table1), and the matching records from the right table (table2). The result is 0 records from the right side, if there is no match.

select `users`.`id`, `users`.`name`, `users`.`email`, `countries`.`name` as `country_name` 
from `users` 
left join `countries` on `countries`.`id` = `users`.`country_id`


Laravel Query :

In this example, select data like id, name email, and country name but if you want all fileds then you can use * to select all data.

public function index()
    $users = User::select('', '', '', ' as country_name')
                    ->leftJoin('countries', '', '=', 'users.country_id')

 Using DB:

$users = DB::table('users')
            ->leftJoin('posts', '', '=', 'posts.user_id')

$users = DB::table('users')
            ->rightJoin('posts', '', '=', 'posts.user_id')



Laravel Left Join with Multiple Condition

Now, I will give example about multiple where condition with aggregate function.

User::leftJoin('posts', '', '=', 'posts.user_id')
       ->where('is_published', true)


You might also like :

Recommended Post
Featured Post
How To Create Candlestick Chart In Laravel 9 Using Highcharts
How To Create Candlestick Char...

In this article, we will see how to create a candlestick chart in laravel 9 using highcharts. A candlestick is a ty...

Read More


Laravel 9 Livewire Datatable Example
Laravel 9 Livewire Datatable E...

In this article, we will see the laravel 9 livewire datatable example. Here, we will learn how to use livewire data...

Read More


Laravel 9 Yajra Datatable Example
Laravel 9 Yajra Datatable Exam...

In this artical we will see laravel 9 yajra datatable example. As we all used datatable on our backend side project, Her...

Read More


How to Get Request Header in Laravel 10
How to Get Request Header in L...

Ever wondered how to access request headers in your Laravel 10 application? Join me as I guide you through a quick and s...

Read More