[英]How can I query this sort of relationship in Eloquent?
模式如下:
Likes
id (pk)
UserID
FreestyleID
Freestyle:
id (pk)
BeatId
Beat:
id (pk)
trackId
Track:
id (pk)
GenreId
Genre:
id (pk)
Title
真的,我想通过他们喜欢的流派ID来获得Freestyle的集合。 我已经尝试了很多事情,包括诸如以下的关系:
Genre model:
public function beat()
{
return $this->hasManyThrough('App\Beat', 'App\Track', 'GenreId', 'TrackId');
}
但是,以上内容将返回如下结果,因为每个曲目最多可以包含三个节拍:
让我知道您是否还需要查看其他内容。
您使用的是正确的方法,但是您将需要更多的代码。 首先,您可以将流派的函数名称更改为beats()-仅出于约定,因为它将返回多个寄存器:P。 其次,通过hasManyThrough,您将获得与流派相关的所有Beats(通过Track)。 然后,您可以访问与该Beat相关的自由式:
击败:
public function freestyles()
{
return $this->hasMany('App\Freestyle');
}
自由式:
public function beat()
{
return $this->belongsTo('App\Beat');
}
public function likes()
{
return $this->hasMany('App\Like');
}
has('freestyles.likes')
因此,您可以执行以下功能(流派模型):
public function beatsWithLikes()
{
return $this->beats()->has('freestyles.likes');
}
希望对您有帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.