を実装しようとしていますZend_Search_Lucene
。以下の条件で実装しました。
- 検索ワード*
- 検索ワード
- 大文字小文字を区別しません
Wildcard search is supported only for non-multiple word terms
しかし、「 」というエラーが発生することがあります
以下は、コントローラーから取得した、検索するコードです。
...
$browseSrArray = array();
if ($postData['name'])
$browseSrArray['name'] = preg_replace('#[^\w()/.%\-&]#', "", $postData['name']);
$results = $manufacturers->browseSearch($browseSrArray);
if(count($results)>0){
foreach ($results as $result) {
$doc = new Zend_Search_Lucene_Document();
// add Fields
$doc->addField(Zend_Search_Lucene_Field::Keyword('AccountNumber', $result['accountid']));
$doc->addField(Zend_Search_Lucene_Field::Keyword('ManufacturesName', strtolower($result['name'])));
$doc->addField(Zend_Search_Lucene_Field::Text('ContactName', $result['contact_name']));
$doc->addField(Zend_Search_Lucene_Field::Keyword('EmailId', strtolower($result['email'])));
$doc->addField( Zend_Search_Lucene_Field::Text('ManufacturesId', $result['manufacturer_id']));
$doc->addField(Zend_Search_Lucene_Field::Text('Manufacturesstatus', $result['status']));
// Add document to the index
$index->addDocument($doc);
}
// Optimize index.
$index->optimize();
if(strlen($postData['name']) > 2)
$query = Zend_Search_Lucene_Search_QueryParser::parse(strtolower($postData['name'].'*'));
else
$query = $postData['name'];
// Search by query
$this->view->hits = $index->find(strtolower($query));
} else {
$this->view->hits = 0;
}
...
以下の条件を修正する必要があります。
例えば、
- 製造名が "
testname-lastname
" の場合、このエラーが発生します。 - メーカー名が "
firstname lastname
" の場合、姓を検索しても lucence から正確な LIKE 結果が得られません。
これを修正するのを手伝ってください。