我在我的项目中使用FOSElasticaBundle搜索我的Player实体。由于我只想在值isactive上搜索具有属性1的实体,所以我遵循了关于“筛选结果并执行默认查询”的文档:FriendsOfSymfony/FOSElasticaBundle/README.md
$query = new \Elastica\Query\QueryString($searchterm);
$term = new \Elastica\Filter\Term(array('isactive' => true));
$filteredQuery = new \Elastica\Query\Filtered($query, $term);
$players = $this->get('fos_elastica.finder.xxx.player')->find($filteredQuery);我的包的配置如下:
fos_elastica:
clients:
default: { host: localhost, port: 9200 }
serializer:
callback_class: FOS\ElasticaBundle\Serializer\Callback
serializer: serializer
indexes:
xxx:
client: default
types:
player:
mappings:
firstname: { boost: 3 }
lastname: { boost: 3 }
serializer:
groups: [elastica, Default]
persistence:
driver: orm
model: xxx\FrontendBundle\Entity\Player
listener: ~
provider: ~
finder: ~现在我想做一些排序,用限制和偏移来减少结果。我怎样才能做到这一点?
我找到了一个解决办法
$finalQuery = new \Elastica\Query($boolQuery);
$finalQuery->setSort(array('price' => array('order' => 'asc')));但是我没有Elastica\Query对象,而且AbstractQuery不支持这个方法。同
$elasticaQuery->addSort($sort);该怎么办呢?在哪里阅读?//
(此外,如果我们已经在这里,那么{boost: 3}到底做了什么呢?)
发布于 2014-02-17 16:56:08
您必须创建一个通用的Elastica\Query()对象。然后可以使用->addSort($sort)将排序添加到此查询中。
稍后,您可以使用->setQuery()分配一个适当的查询;
您的示例应该如下所示
$query = new \Elastica\Query();
$query->addSort(array('price' => array('order' => 'asc')));
$q = new \Elastica\Query\QueryString($searchterm);
$term = new \Elastica\Filter\Term(array('isactive' => true));
$filteredQuery = new \Elastica\Query\Filtered($q, $term);
$query->setQuery($filteredQuery);
$players = $this->get('fos_elastica.finder.xxx.player')->find($query);Boost允许您使一个字段比查询中的其他字段更重要。
https://stackoverflow.com/questions/21833387
复制相似问题