我只是不知道如何使用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);

10-06 01:39