Skip to main content
Quick Tip

`whereHas()` multiple connections

// User Model
class User extends Model
{
protected $connection = 'conn_1';
 
public function posts()
{
return $this->hasMany(Post::class);
}
}
 
// Post Model
class Post extends Model
{
protected $connection = 'conn_2';
 
public function user()
{
return $this->belongsTo(User::class, 'user_id');
}
}
 
// wherehas()
$posts = Post::whereHas('user', function ($query) use ($request) {
$query->from('db_name_conn_1.users')->where(...);
})->get();

Tip given by @adityaricki

Enjoyed This Tip?

Get access to all premium tutorials, video and text courses, and exclusive Laravel resources. Join our community of 10,000+ developers.

Recent Courses

Testing in Laravel 13 For Beginners

26 lessons
1 h 41 min read

Laravel 13 Eloquent: Expert Level

41 lessons
1 h 34 min

How to Structure Laravel 13 Projects

16 lessons
1 h 32 min read

We'd Love Your Feedback

Tell us what you like or what we can improve

Feel free to share anything you like or dislike about this page or the platform in general.