Laravel 5数据库关系类型

时间:2015-03-24 14:44:22

标签: php database laravel eloquent

我想使用Laravel 5模型来检索关系,但我不知道我应该使用哪种关系类型以及如何实现它。

我有4个数据库表:

  1. 用户
  2. 角色
  3. 权限
  4. role_permission
  5. 我需要根据“role_id”列检索“用户”的所有权限。

    我创建了3个模型:

    1. 用户
    2. 作用
    3. 权限
    4. 数据库表“users”包含2列:

      1. ID
      2. ROLE_ID
      3. 数据库表“roles”包含2列

        1. ID
        2. 名称
        3. 数据库表“permissions”包含2列

          1. ID
          2. 名称
          3. 数据库表“role_permission”包含3列,用于定义哪个角色与哪个权限相关联。

            1. ROLE_ID
            2. permission_id
            3. 标志
            4. 我想要实现的是以下语法:

              $user->role // Get the associated "Role"    
              $user->role->permissions // Get the associated permissions for a "Role"  
              App\Role::find(1)->permissions // Get the associated permissions for a "Role"
              

              我确实阅读了关于模型关系的Laravel文档,但我真的不明白。有人理解我想要实现的目标以及如何在模型中实现它吗?也许有一些简单的代码示例,所以我可以理解这些关系以及它们是如何工作的?

              提前致谢。

1 个答案:

答案 0 :(得分:2)

您定义数据库的方式是,您已定义了以下关系:角色和用户之间的一对多关系,以及角色和权限之间的多对多关系。还可以说,角色有很多用户,用户属于角色,角色有很多权限,权限有很多角色。

在Laravel中,一对一关系使用hasOne / belongsTo集建模,一对多关系使用hasMany / belongsTo建模设置,并使用belongsToMany / belongsToMany集对多对多关系建模。

关系在以下模型中定义:

用户:
由于users表包含角色表(role_id)的外键,因此User模型位于一对一/一对多关系的belongsTo端。

class User extends Model {
    public function role() {
        return $this->belongsTo('\App\Role');
    }
}

角色/许可:
具有权限的多对多由具有belongsToMany关系的两个模型完成。数据透视表名称的Laravel约定是单数表名称的字母顺序与下划线分隔符的组合,因此它应该是“permission_role”。由于数据透视表名称不遵循约定,因此必须在关系定义中指定。此外,由于数据透视表上有一个额外的字段,您需要在关系上使用withPivot()方法指定对该字段的访问权限。

class Role extends Model {
    public function users() {
        return $this->hasMany('\App\User');
    }

    public function permissions() {
        return $this->belongsToMany('\App\Permission', 'role_permission')->withPivot('flag');
    }
}

class Permission extends Model {
    public function roles() {
        return $this->belongsToMany('\App\Role', 'role_permission')->withPivot('flag');
    }
}