0

我正在尝试基于用户传入的逗号分隔列表构建一个 queryOr,我将循环遍历并添加值。

到目前为止,我得到了这个只是构建它:

$query = new SugarQuery();
$query->from(BeanFactory::getBean('rdwrk_Request'));
$skills = $query->join('rdwrk_request_skills_rdwrk_request', array('alias' => 'skills'))->joinName();
$query->select(array(array('name', 'requestName'), array('skills.name', 'skillName')));
if($args["requestName"])
{
    $requestName = $args["requestName"];
    if(strpos($requestName, ',') !== false)
    {
        $requestNames = explode(",", $requestName);
        foreach($requestNames as $name)
        {
            $query->where()->queryOr()->contains('name', $name);
        }
    }
    else
    {
        $query->where()->contains('name', $requestName);
    }
}
if($args["skillName"])
{
    $query->where()->contains('skills.name', args["skillName"]);                
}
$results = $query->execute();

有什么方法可以构建它,以便我循环的所有值都进入同一个查询或?

4

1 回答 1

0

您可以将当前的 SugarQuery 对象设置为它自己的变量,然后通过循环将其输入如下:

$currentQuery = $query->where()->queryOr();
foreach($requestNames as $name)
{
    $currentQuery->contains('name', $name);
}

这将在与 queryOr 建立的同一查询对象上调用 contains 函数。由于该$currentQuery变量引用了相同的 SugarQuery 对象,因此$query->execute()稍后运行将包含参数。

于 2017-01-06T14:24:13.520 回答