doutangtan6386 2018-07-26 04:17
浏览 81
已采纳

Laravel 3表Eloquent:关系

I have 3 tables

roles

id `````` |```` `` role ```````` |

1 `````` ```````` Staff

permissions

id ````````| `````````` Name ```````````` |

1 ````````````Manage All Projects

2 ```````````` Manage Clients

acces_permissions

id_permission FK | id_role FK
`````` `` 1 ```````````````````` 1

```````` 2 ```````````````````` 1

and i will have a table with

roles | permissions Name |

Staff | Manage All Projects Manage Clients |

how can o this whit this 3 Models

class roles extends Model
class permissions extends Model
class acces_permissions extends Model
  • 写回答

3条回答 默认 最新

  • dongzongpeng6474 2018-07-26 04:28
    关注

    correct me if im wrong, what you are trying to achieve is get all permissions using the role of a user ..

    the easiest way is to use belongsToMany eloquent relation, in your Role model add this

    public function permissions()
    {
        return $this->belongsToMany('App\Permissions', 'access_permission_table', 'id_role', 'id_permission');
    }
    

    this way, when you call $role->permissions, you'll get all the permission for that role.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大