Lucene多索引目录检索

我们可以使用MultiReaderMultiSearcher搜索多个索引库。
MultiReaderreader=newMultiReader(newIndexReader[]{IndexReader.Open(@"c:\index"),IndexReader.Open(@"\\server\index")});
IndexSearchersearcher=newIndexSearcher(reader);
Hitshits=searcher.Search(query);



IndexSearchersearcher1=newIndexSearcher(reader1);
IndexSearchersearcher2=newIndexSearcher(reader2);
MultiSearchersearcher=newMultiSearcher(newSearchable[]{searcher1,searcher2});
Hitshits=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

Searchable[] getSearchables()
Return the array of Searchables this searches

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