我使用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 org:
“迭代所有命中的速度很慢有两个原因。首先,当你需要超过100次点击时,返回Hits对象的search()方法会在内部重新执行搜索”。
我的问题是有机会将此值“100”更改为“200”吗? 但重要的是我使用罗盘或原始的Lucene。
答案 0 :(得分: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中的说明进行操作,建议更换
相反e。 G。可以使用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的一部分,否则我认为你被困了