我的控制器正在接收一个AgentId
public function save(Int $agent_id, Request $request)因此,现在我需要检查当前用户是否拥有处理此agent_id的权限。
问题是,它们不是直接与关系相连的。
这些模型之间的路径是:
User -> hasMany Workspace -> hasMany Inventory -> hasOne Agent因此,问题是:是否有一种更简单/更干净的方法来检查用户是否与此代理有连接?
到目前为止,我尝试的是循环每个关系级别的所有项。
发布于 2020-10-29 19:51:47
Agent模型与User有关系,因为没有其父数据就不能创建子表行。您可以使用join方法到达User表,如下所示:
$q = Agent::select('agents.*')
->where('id', $agent_id)
->join('inventories', 'inventories.id', '=', 'agents.inventory_id')
->join('workspaces', 'workspaces.id', '=', 'inventories.workspace_id')
->join('users', 'users.id', '=', 'workspaces.workspace_id')
->get();https://stackoverflow.com/questions/64597954
复制相似问题