package query;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.TermQuery;
public class MultiPhraseQuery {
public static void main(String[] args) {
// TODO 自动生成的方法存根
IndexWriter writer = new IndexWriter(INDEX_STORE_PATH, new StandardAnalyzer(), true);
writer.setUseCompoundFile(false);
//创建8个文档
Document doc1 = new Document();
Document doc2 = new Document();
Document doc3 = new Document();
Document doc4 = new Document();
Document doc5 = new Document();
Document doc6 = new Document();
Field f1 = new Field("bookname", "钢铁是怎样炼成的",Field.Store.YES, Field.Index.TOKENIZED);
Field f2 = new Field("bookname", "钢铁是怎样炼成的",Field.Store.YES, Field.Index.TOKENIZED);
Field f3 = new Field("bookname", "钢铁是怎样炼成的",Field.Store.YES, Field.Index.TOKENIZED);
Field f4 = new Field("bookname", "钢铁是怎样炼成的",Field.Store.YES, Field.Index.TOKENIZED);
Field f5 = new Field("bookname", "钢铁是怎样炼成的",Field.Store.YES, Field.Index.TOKENIZED);
Field f6 = new Field("bookname", "钢铁是怎样炼成的",Field.Store.YES, Field.Index.TOKENIZED);
doc1.add(f1);
doc2.add(f2);
doc3.add(f3);
doc4.add(f4);
doc5.add(f5);
doc6.add(f6);
writer.addDocument(doc1);
writer.addDocument(doc2);
writer.addDocument(doc3);
writer.addDocument(doc4);
writer.addDocument(doc5);
writer.addDocument(doc6);
writer.close();
IndexSearcher searcher = new IndexSearcher(INDEX_STORE_PATH);
//构建一个MultiPhraseQuery
MultiPhraseQuery query = new MultiPhraseQuery();
//首先向其中加入查找的短语前缀
query.add(new Term("bookname", "钢"));
//构建三个Term,作为短语前缀
Term t1 = new Term("bookname","铁");
Term t2 = new Term("bookname","和");
Term t3 = new Term("bookname","要");
//再向Query中加入所有的后缀,与前缀一起,它们将组成3个短语
query.add(new Term []{t1, t2, t3});
//打印查询结果
Hits hits = searcher.search(query);
for(int i = 0; i < hits.length(); i++){
System.out.println(hits.doc(i));
}
}