gpt4 book ai didi

symfony - 在 FOSElasticaBundle 中排序

转载 作者:行者123 更新时间:2023-11-29 02:53:51 25 4
gpt4 key购买 nike

我在我的项目中使用 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} 究竟做了什么?)

最佳答案

您必须创建一个通用的 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 允许您在查询中使一个字段比其他字段更重要/更不重要。

关于symfony - 在 FOSElasticaBundle 中排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21833387/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com