Laravel - Eloquent "Has", "With", "WhereHas" - What do they mean?

Matheus Mello
Matheus Mello
September 2, 2023
Cover Image for Laravel - Eloquent "Has", "With", "WhereHas" - What do they mean?

🌟 Understanding Laravel Eloquent "Has", "With", and "WhereHas" 🌟

If you've delved deep into Laravel development, chances are you've come across the powerful Eloquent ORM and its handy relationships feature. Among the several methods provided by Eloquent to define and work with relationships, "has", "with", and "whereHas" are three commonly used methods that can sometimes cause confusion. 🤔

📋 Let's shed some light on the differences between these methods and understand when to use each one of them through a practical example.

🚀 The Scenario: A Blogging Application 🚀

Imagine you're building a blogging application, and you have two models: User and Post. Each User can have multiple Post instances associated with them. Now let's look at how "has", "with", and "whereHas" can be used to query these relationships.

1️⃣ The "has" Method

The has method is used to retrieve records that have a specific relationship. In our example, let's say we want to retrieve all the users who have at least one post. We can use the "has" method like this:

$users = User::has('posts')->get();

This will fetch all the users who have at least one post associated with them. 🙌

2️⃣ The "with" Method

The with method is used to eager load relationships while retrieving records. This means that we can retrieve all the users along with their associated posts. Here's how we can achieve this:

$users = User::with('posts')->get();

Now, each user retrieved will have their associated posts as part of the result. This helps in reducing the number of database queries when accessing the user's posts later in the application. 🎉

3️⃣ The "whereHas" Method

The whereHas method allows us to put constraints on the relationship. Let's say we want to retrieve all the users who have posts containing the word "Laravel" in their title. We can accomplish this as follows:

$users = User::whereHas('posts', function ($query) {
    $query->where('title', 'like', '%Laravel%');
})->get();

Now, we'll get all the users who have at least one post with "Laravel" in the title. This method is useful when we want to filter the parent records based on their relationship's constraints. 😎

📞 Take Action: Share Your Thoughts! 📞

Now that you have a clear understanding of the differences between "has", "with", and "whereHas" in Laravel Eloquent, it's time to put this knowledge into practice and experiment with it in your own projects. Let us know in the comments section below how these methods have helped you in your application development! 💬

If you found this guide helpful, consider sharing it with your fellow developers who might benefit from this valuable information. Happy coding! 🚀✨

Take Your Tech Career to the Next Level

Our application tracking tool helps you manage your job search effectively. Stay organized, track your progress, and land your dream tech job faster.

Your Product
Product promotion

Share this article

More Articles You Might Like

Latest Articles

Cover Image for How can I echo a newline in a batch file?
batch-filenewlinewindows

How can I echo a newline in a batch file?

Published on March 20, 2060

🔥 💻 🆒 Title: "Getting a Fresh Start: How to Echo a Newline in a Batch File" Introduction: Hey there, tech enthusiasts! Have you ever found yourself in a sticky situation with your batch file output? We've got your back! In this exciting blog post, we

Cover Image for How do I run Redis on Windows?
rediswindows

How do I run Redis on Windows?

Published on March 19, 2060

# Running Redis on Windows: Easy Solutions for Redis Enthusiasts! 🚀 Redis is a powerful and popular in-memory data structure store that offers blazing-fast performance and versatility. However, if you're a Windows user, you might have stumbled upon the c

Cover Image for Best way to strip punctuation from a string
punctuationpythonstring

Best way to strip punctuation from a string

Published on November 1, 2057

# The Art of Stripping Punctuation: Simplifying Your Strings 💥✂️ Are you tired of dealing with pesky punctuation marks that cause chaos in your strings? Have no fear, for we have a solution that will strip those buggers away and leave your texts clean an

Cover Image for Purge or recreate a Ruby on Rails database
rakeruby-on-railsruby-on-rails-3

Purge or recreate a Ruby on Rails database

Published on November 27, 2032

# Purge or Recreate a Ruby on Rails Database: A Simple Guide 🚀 So, you have a Ruby on Rails database that's full of data, and you're now considering deleting everything and starting from scratch. Should you purge the database or recreate it? 🤔 Well, my