Lucene 搜索方法(前缀搜索)

PrefixQuery是一种前缀搜索,在检索的时候,常常需要进行某种前缀查找,例如到图书馆查找一本书,可能只能记得书名的前面几个字,这种情况就可以用该种搜索模式。

 

public static void main(String[] args) {
  try {
   IndexSearcher search = new IndexSearcher("d://demo");
   Term term = new Term("bookname","钢");
   PrefixQuery query = new PrefixQuery(term);
   Hits hits = search.search(query);
   for(int i=0;i<hits.length();i++)
   {
    System.out.println(hits.doc(i));
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

 

该类PrefixQuery也是通过传入一个TERM来进行检索,以上面几个例子的索引文件为例子:

结果:

Document<stored/uncompressed,indexed,tokenized<bookname:钢的世界>>
Document<stored/uncompressed,indexed,tokenized<bookname:钢铁战士>>
Document<stored/uncompressed,indexed,tokenized<bookname:钢铁是怎样炼成的>>
Document<stored/uncompressed,indexed,tokenized<bookname:钢和铁是两种金属元素>>
Document<stored/uncompressed,indexed,tokenized<bookname:铁和钢是两种金属元素>>
Document<stored/uncompressed,indexed,tokenized<bookname:钢要比铁有更多的碳元素>>

 

可以看到,以“钢”开头的文档都检索出来了。这种查询方式可能比较慢

你可能感兴趣的:(Lucene)