我只是不知道如何使用Elastica进行自定义查询。我有一个搜索表单来查找产品,用户可以在其中输入名称,选择类别,品牌等。
在我的产品映射中,有一个名为“category_id”的字段,其中包含您可以猜测的类别的ID,还有一个名为“category”的字段,其中包含一个对象。
当我显示所有不带过滤器的产品时,这是此字段的示例:
[category] => Array
(
[id] => 2
[name] => Laptop
[slug] => laptop
[created_at] => 2012-03-12T17:11:42+0000
[updated_at] => 2013-04-25T00:01:04+0000
)
我手动添加了先前的“category_id”字段,但我没有注意到这里有“category”字段。为了不超载我的产品映射,我想知道如何通过指定“类别”字段的ID来构建查询。
这实际上是我的方法:
$elasticaFilterCategory = new \Elastica\Filter\Term();
$elasticaFilterCategory->setTerm('category_id', $category_id]);
我检查了Elastica的文档,我们可以看到setTerm方法接受array():http://elastica.io/api/classes/Elastica.Filter.Term.html#method_setTerm
所以我尝试没有成功:
$elasticaFilterCategory = new \Elastica\Filter\Term();
$elasticaFilterCategory->setTerm('category', array( "id" => $category_id ));
最佳答案
你可以用这样的东西
$elasticaFilterCategory = new \Elastica\Filter\Term();
$elasticaFilterCategory->setTerm('category.id', $category_id);