【问题标题】:$query->with() is working but $query->load() not working in Laravel$query->with() 正在工作,但 $query->load() 在 Laravel 中不起作用
【发布时间】:2021-01-29 10:30:43
【问题描述】:

我有三个模型。

  1. 部分
  2. 主题
  3. 章节

章节有很多主题,主题有很多章节。 我想加载一个包含所有主题的部分以及包含所有章节的主题。 这是我正在尝试的代码:

$section = Section::find(1)->load(['subjects' => function ($query) {
                    $query->load('chapters');
                }]);

这不起作用。 $query->load('chapters') 这部分给了我错误。但如果我尝试这段代码:

$section = Section::find(1)->load(['subjects' => function ($query) {
                $query->with('chapters');
            }]);

这是有效的。我对$query->with() 有一些问题,所以我想改用$query->load()。我应该怎么做才能使用load() 而不是with()>

【问题讨论】:

    标签: laravel eloquent query-builder


    【解决方案1】:

    Eloquent 查询构建器没有名为 load() 的函数。但 Eloquent 模型可以。

    $section = Section::find(1)
                   ->load(['subjects' => function ($query) { // in here you are calling load on a model (Section).
                        $query->load('chapters'); // in here you are calling load on a query builder instance.
                   }]);
    
    • 当你想在获取模型后加载一些关系时,使用load()函数
    • 如果您想在获取模型的同时加载一些关系,请使用with() 函数

    在您的情况下,您已经获取了主题。所以你可以使用load('subject')。但是当你加载主题时(你还没有获取主题),所以你应该打电话给with('chapters')

    编辑 您的第二种方法的简短版本

    $section = Section::find(1)->load(['subjects.chapters');
    

    如果没有特殊要求单独获取部分,更好的方法是在获取部分的同时加载主题和章节。

    $section = Section::with('subjects.chapters')->find(1)
    

    【讨论】:

      【解决方案2】:

      为什么不使用:

      $section = Section::query()->with('subjects.chapters')->find(1)
      

      这将预加载带有章节的主题并让您快速获得结果。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2021-06-28
        • 1970-01-01
        • 1970-01-01
        • 2013-03-29
        • 1970-01-01
        • 1970-01-01
        • 2019-12-17
        相关资源
        最近更新 更多