我对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");
答案 0 :(得分:3)
是的,当您使用QueryParser解析查询时,您将能够进行邻近搜索。
通常,建议使用相同的分析器进行索引和搜索。
BR,
克里斯