Laravel 5 数据库关系类型
Laravel 5 database relation type
我想使用 Laravel 5 模型来检索关系,但我不知道应该使用哪种关系类型以及如何实现它。
我有 4 个数据库 tables:
- 用户
- 角色
- 权限
- role_permission
我需要根据 "role_id" 列检索 "User" 的所有权限。
我创建了 3 个模型:
- 用户
- 角色
- 权限
数据库 table "users" 包含 2 列:
- id
- role_id
数据库 table "roles" 包含 2 列
- id
- 名字
数据库 table "permissions" 包含 2 列
- id
- 名字
数据库 table "role_permission" 包含 3 列,用于定义哪个角色与哪个权限相关联。
- role_id
- permission_id
- 旗帜
我想要实现的是以下语法:
$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 文档,但我真的不明白。有人了解我想要实现的目标以及如何在模型中实现它吗?也许有一些简单的代码示例,这样我就可以理解它们之间的关系以及它们是如何工作的?
提前致谢。
您定义数据库的方式定义了以下关系:角色和用户之间的一对多关系,以及角色和权限之间的多对多关系。也可以说一个角色有很多用户,一个用户属于一个角色,一个角色有很多权限,一个权限有很多角色。
在Laravel中,一对一关系使用hasOne
/belongsTo
集合建模,一对多关系使用hasMany
集合建模/belongsTo
集,多对多关系使用 belongsToMany
/belongsToMany
集建模。
关系在以下模型中定义:
用户:
由于用户 table 包含角色 table (role_id) 的外键,因此用户模型位于 one-to-one/one-to-many 关系的 belongsTo 端。
class User extends Model {
public function role() {
return $this->belongsTo('\App\Role');
}
}
Role/Permission:
具有权限的多对多由具有 belongsToMany 关系的两个模型完成。主元 table 名称的 Laravel 约定是单数 table 名称的组合,按字母顺序,带有下划线分隔符,因此它应该是 'permission_role'。由于枢轴 table 名称不符合约定,因此必须在关系定义中指定。此外,由于您在数据透视 table 上有一个额外的字段,您需要使用关系上的 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');
}
}
我想使用 Laravel 5 模型来检索关系,但我不知道应该使用哪种关系类型以及如何实现它。
我有 4 个数据库 tables:
- 用户
- 角色
- 权限
- role_permission
我需要根据 "role_id" 列检索 "User" 的所有权限。
我创建了 3 个模型:
- 用户
- 角色
- 权限
数据库 table "users" 包含 2 列:
- id
- role_id
数据库 table "roles" 包含 2 列
- id
- 名字
数据库 table "permissions" 包含 2 列
- id
- 名字
数据库 table "role_permission" 包含 3 列,用于定义哪个角色与哪个权限相关联。
- role_id
- permission_id
- 旗帜
我想要实现的是以下语法:
$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 文档,但我真的不明白。有人了解我想要实现的目标以及如何在模型中实现它吗?也许有一些简单的代码示例,这样我就可以理解它们之间的关系以及它们是如何工作的?
提前致谢。
您定义数据库的方式定义了以下关系:角色和用户之间的一对多关系,以及角色和权限之间的多对多关系。也可以说一个角色有很多用户,一个用户属于一个角色,一个角色有很多权限,一个权限有很多角色。
在Laravel中,一对一关系使用hasOne
/belongsTo
集合建模,一对多关系使用hasMany
集合建模/belongsTo
集,多对多关系使用 belongsToMany
/belongsToMany
集建模。
关系在以下模型中定义:
用户:
由于用户 table 包含角色 table (role_id) 的外键,因此用户模型位于 one-to-one/one-to-many 关系的 belongsTo 端。
class User extends Model {
public function role() {
return $this->belongsTo('\App\Role');
}
}
Role/Permission:
具有权限的多对多由具有 belongsToMany 关系的两个模型完成。主元 table 名称的 Laravel 约定是单数 table 名称的组合,按字母顺序,带有下划线分隔符,因此它应该是 'permission_role'。由于枢轴 table 名称不符合约定,因此必须在关系定义中指定。此外,由于您在数据透视 table 上有一个额外的字段,您需要使用关系上的 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');
}
}