繁体   English   中英

Solr搜索按solr1.2中的分数排序

[英]Solr Search sort by score in solr1.2

我的项目之一使用solr1.2,当我在搜索功能中使用“按分数排序”时,它不起作用。我不知道为什么吗?

任何人都可以解释一下。我完全感到困惑。

我的控制器我在做什么:

protected function globalSearch($searchTerm, $productFilter = array())
{
    $solrService = $this->get('syd.solr_service');

    $solrQuery = new SolrQuery('*:*');
    $solrQuery->addField('id')
        ->addField('first_product_slug')
        ->addField('first_product_name')
        ->addField('name')
        ->addField('slug')
        ->addField('thumbnail_path')
        ->addField('product_slug')
        ->addField('design_category_id')
        ->addSortField('score', SolrQuery::ORDER_DESC);
    $solrQuery->set("group", "true"); 
    $solrQuery->set("group.field", "first_product_id"); 
    $solrQuery->set("group.limit", 4); 

    if($searchTerm){
        $filterQueries = array();
        $searchTerms = explode(' ',$searchTerm);
        $searchTerms[] = $searchTerm;
        $searchTerm = '("' . implode('" OR "', $searchTerms) . '")';
        $filterQuery = sprintf(self::SEARCH_STRING, $searchTerm);
        $solrQuery->addFilterQuery($filterQuery);
    }

    if (!empty($productFilter))
    {
        $productFiltersArr = array();
        $productFilterQry = '';
        foreach ($productFilter as $productFilterValue )
        {
            $productFiltersArr[] = 'first_product_slug:' . $productFilterValue;
        }
        $productFilterQry = implode(' OR ', $productFiltersArr);
        $solrQuery->addFilterQuery($productFilterQry);
    }

    $solrQuery->setRows(1000);
    try {
        $solrObject = $solrService->query(
            'SydPrintBundle:DesignTemplate',
            $solrQuery,
            SolrService::WRITER_FORMAT_SOLR_OBJECT
        );
        $templates = $solrObject->offsetGet('grouped')->offsetGet('first_product_id')->offsetGet('groups');
    } 
    catch (\Exception $e) {
        $templates = array();
    }

    if (!$templates) {

        if (!empty($searchTerm)) {
            $this->setFlash('catalog-message', 'No results found for your search.');
        }

        return array();
    }
    if (!$searchTerm) {

        if (!empty($searchTerm)) {
            $this->setFlash('catalog-message', 'No results found for your search.');
        }

        return array();
    }

    return $templates;
} 

当您说when i use "sort by score" in search function it's not working我认为您是在说结果未按分数排序。

这是因为您的主要查询是*:*并且您正在通过过滤查询添加搜索字词,但这不会影响得分。 请参阅https://wiki.apache.org/solr/CommonQueryParameters#fq上显示的内容

This parameter can be used to specify a query that can be used to restrict the super set of documents that can be returned, without influencing score.

因此,如果您将搜索字词过滤器查询作为主要查询,那么您应该会看到按得分排序的结果。

更新:代替

$solrQuery = new SolrQuery('*:*');

采用

$solrQuery = new SolrQuery();

而不是

$solrQuery->addFilterQuery($filterQuery);

采用

$solrQuery->setQuery($filterQuery);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM