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]);

10-05 19:07