雄辩的“超级渴望”嵌套查询可能吗?

问题描述 投票:1回答:1

Mates,我的第一篇文章,搜索和尝试不同的解决方案和方法 - 最后在这里结束。

我有一个包含几个相关表的数据库。客户有一个位置,它有几个设置(生命周期,例如计划,构建,运行),每个设置都有不同的电路。基本上:

客户 - > locations->设置 - >电路

现在我想要一个包含设置和电路信息的位置列表,其中选择了电路的供应商。

我如何用eloquent写这个查询?这是我到目前为止所尝试的,但它似乎忽略了“供应商”条款......

$locations = Locations::with(
    ['settings' => function($query) use ($request)
        {
            $query->with(
                ['circuits' =>function($query2) use ($request)
                    {
                        $query2->where('supplier', $request->supplier);
                    }
                ]
            );                  
        }
    ])
    ->where('customer_id', $customers_id)
    ->orderBy('country')
    ->orderBy('city')
    ->get(); 

我敢肯定,所有“hasMany”和“belongsTo”扩展都可用。感谢您阅读和回答udowsky

更新:工作代码,基于Enver的提示:

$locations = Locations::with('settings')
    ->whereHas('settings.circuits', function($query) use ($request)
        {
            $query->where('supplier', $request->supplier);
        }
        )
    ->where('customer_id', $report->customers_id)
    ->orderBy('country')
    ->orderBy('city')
    ->get();

HasManyThrough方法也顺利进行:

扩展位置模型:

public function circuits()
{
    return $this->hasManyThrough('App\Circuits', '\App\Settings');
}

然后使用此查询:

$locations = Locations::with('circuits')
    ->whereHas('circuits', function($query) use ($request)
        {
            $query->where('supplier', $request->supplier);
        }
    )
    ->where('customer_id', $report->customers_id)
    ->orderBy('country')
    ->orderBy('city')
    ->get();

谢谢你们!

laravel eloquent eager-loading relation nested-queries
1个回答
1
投票

您可以使用嵌套关系查询和急切加载。

例:

$relation_sort = 'asc';
$nested_sort = 'desc';

$result = Model::with([
   'relation' => function($query) use($relation_sort){
      $query->orderBy('relation_column', $relation_sort);
   },
   'relation.nested' => function($query) use($nested_sort){
      $query->orderBy('nested_relation_column', $nested_sort);
   }
])->whereHas('relation', function($query){
    //Relation exists check.
    $query->where('price', '>', 100);
})->whereHas('relation.nested', function($query) use($search_param){
    //Nested Relation search.
    $query->where('search_column', 'LIKE', $search_param);
})->get();
© www.soinside.com 2019 - 2024. All rights reserved.