[英]Compass Lucene hits
我在上面使用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 Apacheorg:
“迭代所有匹配的速度很慢,原因有两个。首先,当您需要超过100个匹配时,返回Hits对象的search()方法将在内部重新执行搜索。”
我的问题是是否有机会将此值“ 100”更改为“ 200”? 但重要的是我既不使用罗盘也不使用原始的Lucene。
我在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的一部分,否则我认为您会陷入困境
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.