1

を実装しようとしていますZend_Search_Lucene。以下の条件で実装しました。

  1. 検索ワード*
  2. 検索ワード
  3. 大文字小文字を区別しません

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

以下の条件を修正する必要があります。

例えば、

  1. 製造名が " testname-lastname" の場合、このエラーが発生します。
  2. メーカー名が " firstname lastname" の場合、姓を検索しても lucence から正確な LIKE 結果が得られません。

これを修正するのを手伝ってください。

4

0 に答える 0