http://lucene.apache.org/java/2_3_1/api/core/org/apache/lucene/search/MultiPhraseQuery.html
对于示例“ Microsoft应用程序*”,他说使用IndexReader.term()
,但是返回TermEnum
,如何将其放在MultiPhraseQueryParser
中?
编辑:
或者有人告诉我如何在7.5 GB索引上以更好的方式在Microsoft应用*上进行搜索!
最佳答案
您需要在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]);