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