5) 第一章 初识Lucene:理解核心搜索类

 

 

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的结果集。

 

 

 

 

你可能感兴趣的:(Lucene)