如果所有args(1,2)之一匹配并且我需要所有args必须具有使用者的degree.id,则此术语给出结果
在这里我有这样的数据
"id": 66,
"name": null,
"degrees": [
{
"id": 1,
"name": "BCA",
},{
"id": 2,
"name": "MCA",
}
]
所以我需要,如果BCA和MCA两个学位都存在,那么只有那些记录会到达结果中
$term = new \Elastica\Query\Terms();
$term->setTerms('degrees.id', array('1','2'));
return $boolQuery->addMust($term);
最佳答案
您使用setTerms
所做的实际上是OR
字段上的degrees
。
要进行AND
查询,建议使用Elastica\Query\BoolQuery
类,如下所示:
$BCAQuery = new Elastica\Query\Term();
$BCAQuery->setTerm('degree.id', 1);
$MCAQuery = new Elastica\Query\Term();
$MCAQuery->setTerm('degree.id', 2);
$boolQuery = new BoolQuery();
$boolQuery->addMust($BCAQuery);
$boolQuery->addMust($MCAQuery);
请记住,如果将
degrees
映射为nested
,则可以将您的 bool(boolean) 查询与Elastica\Query\Nested
一起使用$degreesQuery = new Elastica\Query\Nested();
$degreeQuery->setPath('degrees');
$degreesQuery->setQuery($boolQuery);
关于elasticsearch - 如何在 Elasticsearch 中匹配数组中的所有参数传递?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39532070/