8

我在上面使用了 Lucene 和 Compass,但我遇到了一个问题:

          try {
      
       CompassHits hits = compassQuery.hits();
       for (CompassHit compassHit : hits) {
        if (results.size() >= maxResults) {
         Log.info(this, "Number of results exceeded %,d for query %s", maxResults, query);
         break;
        } else {
    
         results.add((T) compassHit.getData());
        }
       }
       

  } 

当数据通过compassHit.getData());并且命中 100 时,它会重新执行搜索,是否有可能将其更改为 200 或更多?

编辑:

来自 wiki apache 组织:

“迭代所有命中很慢,原因有两个。首先,当您需要超过 100 个命中时,返回 Hits 对象的 search() 方法会在内部重新执行搜索”。

我的问题是有机会将此值“100”更改为“200”吗?但重要的是我使用的是指南针,也不是原始的 Lucene。

4

1 回答 1

2

我在 2.9.2 中查看了 Hits 的来源。它是硬编码的。好像是硬编码

 Hits(Searcher s, Query q, Filter f) throws IOException {
    this.weight = q.weight(s);
    this.searcher = s;
    this.filter = f;
    this.nDeletions = countDeletions(s);
    getMoreDocs(50);
    this.lengthAtStart = this.length;
  }

如果您没有使用 Compass,您可以按照 JavaDoc for Hits 中的说明进行操作,该说明建议更换

相反,例如可以使用 TopDocCollector 和 TopDocs:

  TopDocCollector collector = new TopDocCollector(hitsPerPage);
   searcher.search(query, collector);
   ScoreDoc[] hits = collector.topDocs().scoreDocs;
   for (int i = 0; i < hits.length; i++) {
     int docId = hits[i].doc;
     Document d = searcher.doc(docId);
     // do something with current hit
     ...

但是既然你是,除非你愿意重写 Compass 的一部分,我认为你被卡住了

于 2011-05-11T19:13:50.947 回答