use*_*571 7 php relational-database laravel eloquent
在Eloquent的文档中,据说我可以将所需关系的键传递给hasManyThrough。
假设我有名为 Country、User、Post 的模型。通过用户模型,国家模型可能有许多帖子。也就是说,我可以直接调用:
$this->hasManyThrough('Post', 'User', 'country_id', 'user_id');
Run Code Online (Sandbox Code Playgroud)
到目前为止一切正常!但是我怎样才能只为 id 为 3 的用户获取这些帖子?
有人可以帮忙吗?
小智 6
$user_id = 3;
$country = Country::find($country_id);
$country->posts()->where('users.id', '=', $user_id)->get();
Run Code Online (Sandbox Code Playgroud)
所以这里是这样的:
型号:Country有很多User有很多Post
这使我们可以hasManyThrough在您的问题中使用like:
// Country model
public function posts()
{
return $this->hasManyThrough('Post', 'User', 'country_id', 'user_id');
}
Run Code Online (Sandbox Code Playgroud)
您想获取此关系的给定用户的帖子,因此:
$country = Country::first();
$country->load(['posts' => function ($q) {
$q->where('user_id', '=', 3);
}]);
// or
$country->load(['posts' => function ($q) {
$q->has('user', function ($q) {
$q->where('users.id', '=', 3);
});
})
$country->posts; // collection of posts related to user with id 3
Run Code Online (Sandbox Code Playgroud)
但是如果你使用它,它会更容易,更易读和更有说服力:(因为当你在寻找 ID 为 3 的用户的帖子时,它与国家无关)
// User model
public function posts()
{
return $this->hasMany('Post');
}
// then
$user = User::find(3);
// lazy load
$user->load('posts');
// or use dynamic property
$user->posts; // it will load the posts automatically
// or eager load
$user = User::with('posts')->find(3);
$user->posts; // collection of posts for given user
Run Code Online (Sandbox Code Playgroud)
总结一下:hasManyThrough是一种直接获取嵌套关系的方法,即。给定国家/地区的所有帖子,而不是搜索特定through型号。
| 归档时间: |
|
| 查看次数: |
12260 次 |
| 最近记录: |