首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel 5数据库关系类型

Laravel 5数据库关系类型
EN

Stack Overflow用户
提问于 2015-03-24 14:44:22
回答 1查看 1.2K关注 0票数 2

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

我有4个数据库表:

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

我需要根据"role_id“列检索”用户“的所有权限。

我创造了三个模型:

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

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

  1. id
  2. role_id

数据库表“角色”包含2列。

  1. id
  2. 名字

数据库表“权限”包含2列。

  1. id
  2. 名字

数据库表"role_permission“包含3列,这些列定义与哪个权限关联的角色。

  1. role_id
  2. permission_id
  3. 标志

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

代码语言:javascript
复制
$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代码示例,这样我就可以理解它们之间的关系以及它们是如何工作的?

提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-24 15:53:15

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

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

在下面的模型中定义了这些关系:

用户:

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

代码语言:javascript
复制
class User extends Model {
    public function role() {
        return $this->belongsTo('\App\Role');
    }
}

角色/许可:

具有权限的多对多模型是由具有belongsToMany关系的两个模型完成的。pivot表名的Laravel约定是单数表名(按字母顺序排列)和下划线分隔符的组合,因此它应该是‘Laravel_ for’。由于枢轴表名称不遵循约定,所以必须在关系定义中指定它。此外,由于在透视表上有一个额外的字段,所以需要使用关系上的withPivot()方法指定对该字段的访问。

代码语言:javascript
复制
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');
    }
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29235586

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档