FOSElastica捆绑订单查询

问题描述 投票:0回答:1

我正在将 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);

我怎样才能做到这一点?

谢谢

symfony elasticsearch
1个回答
6
投票

尝试创建一个

\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
代表每个的基本类型各个查询类型(范围、模糊、术语等)。

© www.soinside.com 2019 - 2024. All rights reserved.