我正在将 FOSElasticaBundle 集成到我的 Symfony 2.3 项目中,我需要按价格属性对结果进行排序。
这是我的代码:
$finder = $this->container->get('fos_elastica.finder.website.product');
$fieldTerms = new \Elastica\Query\Terms();
$fieldTerms->setTerms('taxon_ids', $taxon_ids_array);
$boolQuery->addMust($fieldTerms);
$resultSet = $finder->find($boolQuery);
我怎样才能做到这一点?
谢谢
尝试创建一个
\Elastica\Query
对象,其中也包含排序信息,然后将其发送到查找器:
$finder = $this->container->get('fos_elastica.finder.website.product');
$fieldTerms = new \Elastica\Query\Terms();
$fieldTerms->setTerms('taxon_ids', $taxon_ids_array);
$boolQuery->addMust($fieldTerms);
$finalQuery = new \Elastica\Query($boolQuery);
$finalQuery->setSort(array('price' => array('order' => 'asc')));
$resultSet = $finder->find($finalQuery);
查看有关排序参数的elasticsearch文档以了解如何正确使用它。
注意:
\Elastica\Query
与 \Elastica\Query\AbstractQuery
完全不同,第一个封装了您可以发送到 _search
API 端点的所有内容(方面、排序、解释等...) AbstractQuery
代表每个的基本类型各个查询类型(范围、模糊、术语等)。