Eloquent hasManyThrough a belongsTo 关系?

Posted

技术标签:

【中文标题】Eloquent hasManyThrough a belongsTo 关系?【英文标题】:Eloquent hasManyThrough a belongsTo relationship? 【发布时间】:2020-02-02 07:30:46 【问题描述】:

我正在 Laravel 中实现一个简单的用户角色和权限模型,但我不确定我需要的 Eloquent 关系是否存在。我想返回用户权限的关系,但这是通过角色模型。一个用户通过role_id只有一个角色,但是一个角色有很多权限。

用户 belongsTo => 角色 hasMany => 权限

我想要 User->permissions() 的 Eloquent 关系方法,但 hasManyThrough 不是正确的关系结构。

有什么想法吗?

【问题讨论】:

【参考方案1】:

像这样。

用户

public function permissions()

    return $this->role->permissions;

【讨论】:

【参考方案2】:

您可以使用HasManyThrough 关系:

class User extends Model

    public function permissions()
    
        return $this->hasManyThrough(
            Permission::class, Role::class, 'id', null, 'role_id'
        );
    

【讨论】:

以上是关于Eloquent hasManyThrough a belongsTo 关系?的主要内容,如果未能解决你的问题,请参考以下文章

Eloquent hasManyThrough 也获取中间表信息

Laravel Eloquent: hasManyThrough 多对多关系

拉拉维尔 |使用 Eloquent hasManyThrough

如何使用 eloquent hasmanythrough 或 hasonethrough 在 laravel 中加入 3 个表

查询关系 Laravel Eloquent ORM

Laravel Eloquent - 相当于第一个()?