首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用雄辩的关系通过关系和特定参数检索模型

使用雄辩的关系通过关系和特定参数检索模型
EN

Stack Overflow用户
提问于 2014-06-04 14:51:40
回答 1查看 127关注 0票数 0

我一直在努力将以下查询转换为雄辩:

代码语言:javascript
运行
复制
SELECT * FROM induction_modules INNER JOIN inductions ON induction_modules.induction_id = inductions.id INNER JOIN induction_user ON induction_user.induction_id = inductions.id WHERE induction_user.user_id = 1 AND induction_modules.id = 56;

这些关系的定义如下:

  • 用户belongsToMany归纳
  • 感应belongsToMany用户
  • InductionModule belongsTo诱导(并与hasOne逆转)
  • InductionModuleItem belongsTo InductionModule (与hasOne相反)。

现在我的职能如下:

代码语言:javascript
运行
复制
/**
* Find specific induction module of user
*
* @param int $id
* @param int $inductionModuleID
* @param array $with
* @return Illuminate\Database\Eloquent\Model|null
*/
public function inductionModule($id, $inductionModuleID, $with = array())
{
    $user = $this->find($id);

    if ($user)
    {
          return /* HOW DO I GET THE MODULE WITH ITS ITEMS?? */
    }

    return null;
}

理想情况下,我想做的是:

代码语言:javascript
运行
复制
$inductionModule = $user->inductions()->modules()->with('items)->WHEREMODULEID=56.

谢谢你的帮忙!

EN

回答 1

Stack Overflow用户

发布于 2014-06-04 16:55:49

这应该对你有用,但我还没试过。

代码语言:javascript
运行
复制
$user = User::with(array('inductions.modules.items' => function($q)
{
    $q->where('induction_modules.id', 56);      
}))->find(1);

foreach($user->inductions as $induction) {
    // echo $induction->description;
    foreach($induction->modules as $module) {
        // echo $module->description;
        foreach($module->items as $item) {
            // echo $item->description;
        }
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24040748

复制
相关文章

相似问题

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