首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >laravel -如何检查子关系是否存在

laravel -如何检查子关系是否存在
EN

Stack Overflow用户
提问于 2020-10-29 19:27:23
回答 1查看 98关注 0票数 0

我的控制器正在接收一个AgentId

代码语言:javascript
复制
public function save(Int $agent_id, Request $request)

因此,现在我需要检查当前用户是否拥有处理此agent_id的权限。

问题是,它们不是直接与关系相连的。

这些模型之间的路径是:

代码语言:javascript
复制
User -> hasMany Workspace -> hasMany Inventory -> hasOne Agent

因此,问题是:是否有一种更简单/更干净的方法来检查用户是否与此代理有连接?

到目前为止,我尝试的是循环每个关系级别的所有项。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-29 19:51:47

Agent模型与User有关系,因为没有其父数据就不能创建子表行。您可以使用join方法到达User表,如下所示:

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

https://stackoverflow.com/questions/64597954

复制
相关文章

相似问题

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