在 for each 循环中重新应用 laravel where 语句
Re-apply laravel where statement in a for each loop
如何在 for each 循环中对特定集合重新应用 where()
语句。
我目前正在循环我的参数,我想在 where()
语句中对每个参数进行循环,这样我就可以使用这些 where()
语句
过滤集合
我的 foreach 在下面:它目前正在获取所有 where()
结果并将它们合并在一起,但我希望所有 where()
语句应用于 1 个单个集合,以便将它们过滤掉。
$guides = new Collection;
foreach($request->query() as $key => $value){
if($guides->isEmpty()){
$guides = SupportGuideTranslation::where($key, $value)->get();
}
else{
$guides = $guides->toBase()->merge(SupportGuideTranslation::where($key, $value)->get());
}
}
$guides = $guides->unique();
这些是我的参数:
?active=2&language_id=2
这是$request->query()
的结果:
^ array:2 [▼
"active" => "2"
"language_id" => "2"
]
我现在的结果是我得到了 6 条记录(而不是 2 条)。
- 3 条记录 language_id=2 且 active=1(错误)
- 1 条记录 language_id=1 且 active=2(错误)
- 2 条记录 language_id=2 且 active=2(正确)
我想要的是它只显示遵循两个参数规则的 2 条记录,而不是合并 2 个单独的集合。
您可以在不执行查询的情况下添加到 QueryBuilder
,您所做的是每次迭代执行一个查询。因此,改为构建正确的查询,然后执行它。
$query = SupportGuideTranslation::query();
foreach ($request->query() as $key => $value) {
$query->where($key, $value);
}
$translations = $query->get();
如何在 for each 循环中对特定集合重新应用 where()
语句。
我目前正在循环我的参数,我想在 where()
语句中对每个参数进行循环,这样我就可以使用这些 where()
语句
我的 foreach 在下面:它目前正在获取所有 where()
结果并将它们合并在一起,但我希望所有 where()
语句应用于 1 个单个集合,以便将它们过滤掉。
$guides = new Collection;
foreach($request->query() as $key => $value){
if($guides->isEmpty()){
$guides = SupportGuideTranslation::where($key, $value)->get();
}
else{
$guides = $guides->toBase()->merge(SupportGuideTranslation::where($key, $value)->get());
}
}
$guides = $guides->unique();
这些是我的参数:
?active=2&language_id=2
这是$request->query()
的结果:
^ array:2 [▼
"active" => "2"
"language_id" => "2"
]
我现在的结果是我得到了 6 条记录(而不是 2 条)。
- 3 条记录 language_id=2 且 active=1(错误)
- 1 条记录 language_id=1 且 active=2(错误)
- 2 条记录 language_id=2 且 active=2(正确)
我想要的是它只显示遵循两个参数规则的 2 条记录,而不是合并 2 个单独的集合。
您可以在不执行查询的情况下添加到 QueryBuilder
,您所做的是每次迭代执行一个查询。因此,改为构建正确的查询,然后执行它。
$query = SupportGuideTranslation::query();
foreach ($request->query() as $key => $value) {
$query->where($key, $value);
}
$translations = $query->get();