如何为PhraseQuery搜索设置Lucene标准分析器?

时间:2011-04-18 05:57:06

标签: lucene

我对Lucene的各种教程的印象是,如果我做了类似的事情:

IndexWriter writer = new IndexWriter(indexPath, new StandardAnalyzer(Version.LUCENE_CURRENT), true, IndexWriter.MaxFieldLength.LIMITED);

Document doc = new Document();
Field title = new Field("title", titlefield, Field.Store.YES, Field.Index.ANALYZED);
doc.add(title);
writer.addDocument(doc);
writer.optimize();
writer.close();

IndexReader ireader = IndexReader.open(indexPath);
IndexSearcher indexsearcher = new IndexSearcher(ireader);

Term term1 = new Term("title", "one");
Term term2 = new Term("title", "two");
PhraseQuery query = new PhraseQuery();
query.add(term1);
query.add(term2);
query.setSlop(2);

Lucene应该返回包含“one”和“two”的标题字段的所有查询,彼此相差2个字。但我没有得到任何结果,因为我没有使用StandardAnalyzer进行搜索。那怎么能在Lucene进行邻近搜索呢?以下queryParser是否允许进行邻近搜索(使用代字号?)

QueryParser queryParser = new QueryParser("title",new StandardAnalyzer());
Query query = queryParser.parse("test");

1 个答案:

答案 0 :(得分:3)

是的,当您使用QueryParser解析查询时,您将能够进行邻近搜索。

通常,建议使用相同的分析器进行索引和搜索。

BR,

克里斯