Lucene多索引目录检索

我们可以使用MultiReader或MultiSearcher搜索多个索引库。
MultiReader reader=newMultiReader(newIndexReader[]{IndexReader.Open(@"c:\index"),IndexReader.Open(@"\\server\index")});
IndexSearcher searcher=newIndexSearcher(reader);
Hits hits=searcher.Search(query);

或

IndexSearcher searcher1=newIndexSearcher(reader1);
IndexSearcher searcher2=newIndexSearcher(reader2);
MultiSearcher searcher=newMultiSearcher(newSearchable[]{searcher1,searcher2});
Hits hits=searcher.Search(query);

还可以使用ParallelMultiSearcher进行多线程并行搜

MultiSearcher介绍<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

MultiSearcher原理是对一个IndexSearcher的数组进行循环遍历。分别进行查找,然后合并,使用HitCollector收集后返回。

eg:

由IndexSearcher——>MultiSearcher

创建两个IndexSearcher,以实现在多个索引目录进行查询

IndexSearcher searcher1=new IndexSearcher(INDEX_STORE_PATH1);

IndexSearcher searcher2=new IndexSearcher(INDEX_STORE_PATH2);

IndexSearcher[] searchers={searcher1,searcher2};

//使用MultiSearcher进行多域搜索

MultiSearcher searcher=new MultiSearcher(searchers);

Hits hits=searcher.search(q);

由MultiSearcher——>IndexSearcher
 

 

你可能感兴趣的:(多线程,xml,Microsoft,Lucene,Office)