我们可以使用 MultiReader 或 MultiSearcher 搜索多个索引库。
MultiReader reader = new MultiReader(new IndexReader[] { IndexReader.Open(@"c:/index"), IndexReader.Open(@"//server/index") });
IndexSearcher searcher = new IndexSearcher(reader);
Hits hits = searcher.Search(query);
或
IndexSearcher searcher1 = new IndexSearcher(reader1);
IndexSearcher searcher2 = new IndexSearcher(reader2);
MultiSearcher searcher = new MultiSearcher(new Searchable[] { searcher1, searcher2 });
Hits hits = searcher.Search(query);
还可以使用 ParallelMultiSearcher 进行多线程并行搜
MultiSearcher介绍
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
Searchable[] getSearchables()
Return the array of Searchables this searches