我们可以使用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