我想在我网站的首页创建搜索框,但我不知道如何使用 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文件中,这是渲染,我不知道我会写什么。
答案 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)