1. IndexSearcher
IndexSearcher用来搜索由IndexWriter索引的内容:它是与索引文件之间的重要通道,并提供了一些搜索方法。你可以把IndexSearcher理解成这样一个类:它以"只读"方式打开索引文件。它提供了大量搜索方法,其中一些方法继承自其抽象父类Searcher. 其典型用法如下:
IndexSearcher searcher = new IndexSearcher("/tmp/index"); Query q = new TermQuery(new Term("contents", "lucene")); TopDocs hits = searcher.search(q, 10); searcher.close();
2. Term
Term是搜索的基本单元。和Field对象相像,它也包含了一对字符串信息:域名和对应域值。值得一提的是,Term对象在索引阶段也会被调用,只不过一切都在Lucene的内部实现,你不需要关心它。一个典型的调用方式是在TermQuery中构造Term:
Query q = new TermQuery(new Term("contents", "patent")); TopDocs hits = searcher.search(q, 10);
3. Query
Lucene有诸多Query子类,目前接触到的是TermQuery. 其它还有:BooleanQuery, PhraseQuery, PrefixQuery, PhrasePrefixQuery, RangeQuery, FilteredQuery 和 SpanQuery. 这些类中包含了大量的实用方法如setBoost(float)
4. TermQuery
TermQuery是Lucene支持的最基础的查询类。它被用来匹配包含了特定值的域的文档。
5. TopDocs
TopDocs是一个简单的指针容器,它指向top N的结果集。