13

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

我怎么能做到这一点?

在我的项目Solr bundle 中使用这个:

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

在基本树枝文件中:

<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;

}

但是在渲染的树枝文件中,我不知道我会写什么。

4

4 回答 4

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

于 2013-01-26T15:10:56.823 回答
0

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

于 2013-09-24T12:51:16.037 回答
0

您通过以下方式获得 GET 参数

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

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

公共函数 anagraficaAction(请求 $request)

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

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

$request = $this->get('request');

使用它,您可以将 setParameter 更改为:

setParameter('nome', $searchName)

于 2013-10-02T13:06:00.357 回答
0

试试这样的..

控制器.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>
于 2013-01-22T12:21:57.807 回答