在 for each 循环中重新应用 laravel where 语句

问题描述

如何在 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();

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...