使用Solr在Symfony2中搜索框

时间:2012-12-26 13:50:53

标签: php search symfony solr

我想在我网站的首页创建搜索框,但我不知道如何使用 Solr 创建一个。我的所有网站都是在 Symfony2 中开发的。我不使用数据库进行搜索。

我怎么能这样做?。

在我的项目 Solr 包中使用此:

use SolrClient;
use SolrQuery;
use SolrObject;
use SolrDocument;
use SolrInputDocument;

在基础 twig 文件中:

<form action="{{ path("home_search") }}" method="get">
  <input type="search" name="search"><br>
  <input type="submit" value="search">
</form>

我的控制器的一些例子:

public function searchAction($templateName = '')
{
 $solrService = $this->get('rocket.solr_service');

    $solrQuery = new SolrQuery('*:*');
    $solrQuery->addField('id')
        ->addField('name');


    if (!empty($templateName)) {
        $solrQuery->addFilterQuery(sprintf('name:"%s" OR design_template_tag_name:"%1$s" OR design_category_name:"%1$s"',
                                           $templateName));
    }


    $solrQuery->setRows(1000);

    $solrObject = $solrService->query(
        'RocketBraPrintBundle:DesignTemplate',
        $solrQuery,
        SolrService::WRITER_FORMAT_SOLR_OBJECT
    );

    $templates = $solrObject->offsetGet('response')->offsetGet('docs');
    if (!$templates) {

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

        return array();
    }

    return $templates;

}

但在twig文件中,这是渲染,我不知道我会写什么。

4 个答案:

答案 0 :(得分:2)

您可以使用https://github.com/nelmio/NelmioSolariumBundle使用日光浴实施

非常适合更好的solr查询

我已经使用它了

这里是一个样本

    $query = 'foo';

    $page = 1;
    if (array_key_exists('page', $params)) {
        $page = (int) $params['page'];
    }
    $rows = 10;
    if (array_key_exists('limit', $params)) {
        $rows = (int) $params['limit'];
    }

    $solarium = $this->get('solarium.client');

    //select
    $select = $solarium->createSelect();
    $escapedQuery = $select->getHelper()->escapePhrase($query);

    //dismax
    $dismax = $select->getDisMax();
    // override the default setting of 'dismax' to enable 'edismax'
    $dismax->setQueryParser('edismax');
    //fields
    $dismax->setQueryFields(
                    array('title^5','description^0.7'));

    $select->setQuery($escapedQuery);

    //limit
    $select->setRows($rows);
    $select->setStart(($page - 1) * $rows);

    //type spot only
    $select->createFilterQuery('typeFilter')
            ->setQuery(sprintf('type:%s', 'spot'));

    $resultset = $solarium->select($select);

使用foreach或twig“for in”来显示你的solr doc

答案 1 :(得分:0)

尝试这样的事情......

Controller.php这样:

public function searchAction($templateName = '')
{
    // ------
    // ------

    $resultset = $solrObject->offsetGet('response');

    // Do some error checks

    return array('resultset'=>$resultset);

}

树枝:

<ul>
{% for doc in resultset %}
  <li> {{ doc.name }} </li>
{% endfor %}
</ul>

答案 2 :(得分:0)

我还没有尝试过,但您可以尝试在Symfony2中使用这个新的Jobeet tutorial来解释如何构建系统以及如何在其中使用Solr。
我希望这有帮助。

答案 3 :(得分:0)

您可以通过

获得GET参数

$ searchName = $ request-&gt; query-&gt; get('search_name');

但是为此你还需要$ request变量。您可以将其用作参数并将方法签名更改为:

public function anagraficaAction(Request $ request)

这样,您可以在方法中调用$ request参数。

另一种方法是在方法中获取当前控制器的请求。

$ request = $ this-&gt; get('request');

使用此功能,您可以将setParameter更改为:

setParameter('nome',$ searchName)