Laravel 5数据库关系类型


Laravel 5 database relation type

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

我有4个数据库表:

  1. 用户
  2. 角色
  3. 权限
  4. 角色权限

我需要根据"角色id"列检索"用户"的所有权限。

我创建了3个模型:

  1. 用户
  2. 角色
  3. 权限

数据库表"users"包含2列:

  1. id
  2. 角色id

数据库表"角色"包含2列

  1. id
  2. 名称

数据库表"权限"包含2列

  1. id
  2. 名称

数据库表"role_permission"包含3列,用于定义哪个role与哪个permission关联。

  1. 角色id
  2. permission_id
  3. 旗帜

我想要实现的是以下语法:

$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文档,但我真的不明白。有人明白我想要实现什么以及如何在模型中实现它吗?也许用一些simpel代码示例,这样我就可以理解它们之间的关系以及它们是如何工作的?

提前谢谢。

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

在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');
    }
}