0

我刚刚开始使用 FOSElasticaBundle,到目前为止发现它真的很好用。我不确定是我对 bundle/Elastica 的无知还是我对 ElasticSearch 的一般知识缺乏了解,但是是否可以使用分页进行 CustomScore 查询?

如果我尝试在 CustomQuery 对象上调用 setFrom/setSize,我会被告知这些方法不存在。如果我在那里创建一个 Query 对象和 setFrom 和 size 并将这个查询传递给 CustomScore 查询对象,那么分页参数将被忽略。我已经包含了我的代码副本,以说明它的价值......

        $queryString = new QueryString();
        $queryString->setFields(array('_all'))
            ->setDefaultOperator('OR')
            ->setQuery($terms);

        $query = new \Elastica\Query();
        $query->setQuery($queryString);
        $query->setSize($maxItems);
        $query->setFrom(($page - 1) * $maxItems);

        $custScoreQuery = new CustomScore();
        $custScoreQuery->setQuery($query);
        $custScoreQuery->setScript("_score * (doc['section.id'] == 7) ? 0.5 : 1");
        $index   = $this->get('fos_elastica.index.search_en_gb');
        $results = $index->search($custScoreQuery);

任何帮助都欣然接受:o)

4

1 回答 1

6

Size 和 From 必须应用于顶级查询,您在这里会丢失它们。

尝试这个:

$queryString = new QueryString();
$queryString->setFields(array('_all'))
        ->setDefaultOperator('OR')
        ->setQuery($terms);

$custScoreQuery = new CustomScore();
$custScoreQuery->setQuery($queryString);
$custScoreQuery->setScript("_score * (doc['section.id'] == 7) ? 0.5 : 1");

$query = new \Elastica\Query();
$query->setQuery($custScoreQuery);
$query->setSize($maxItems);
$query->setFrom(($page - 1) * $maxItems);

$index   = $this->get('fos_elastica.index.search_en_gb');
$results = $index->search($query);

另外,打开Elastica中的日志,就能看到Json查询中是否有“size”和“offset”。话虽如此,分页当然适用于自定义分数。

于 2013-09-10T15:49:09.857 回答