Lucene多索引目录检索

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

你可能感兴趣的:(多线程,c,Lucene,query,Path)