http://lucene.apache.org/java/2_3_1/api/core/org/apache/lucene/search/MultiPhraseQuery.html
对于示例“Microsoft app *”,他说使用IndexReader.term()
但返回TermEnum
,如何将其放入MultiPhraseQueryParser
?
编辑:
或者有人告诉我如何以更好的方式搜索 Microsoft app * 超过7.5 GB的索引!!
答案 0 :(得分:4)
您需要迭代TermEnum才能获得条款。您可以迭代TermEnum以获取以“app”开头的术语,如下所示。
TermEnum te = reader.terms(new Term("field", "app"));
List<Term> termList = new LinkedList<Term>();
while(te.next()) {
Term t = te.term();
if (!t.field().equals("field") || !t.text().startsWith("app")) {
break;
}
termList.add(t);
}
Term[] terms = termList.toArray(new Term[0]);