您的位置:首页 > 其它

Lucene查询结果Hits的二次封装

2007-09-24 17:08 267 查看
原文发布在:http://paomadeng.javaeye.com/blog/126687

OSPod.Forum使用Lucene作为搜索引擎核心,对于Lucene的分页,OSPod对Hits进行了二次封装,取出所需结果集后,关闭Hits,极大提高搜索效率。参考代码如下:

/**
* 索引分页对象
*/
private Pagination page;
/**
* 命中结果数据数
*/
private int hitsLength = 0;
/**
* 当前分页的命中结果集
*/
private List results;
/**
* 用于分页的最大结果数
*/
private int total = 0;

/**
* 构造方法,创建并初始化索引结果集对象
* @param hits 查询命中结果
* @param start 结果集提取其实位置
* @param count 当前提取数
* @param totalLimit 用于分页的最大结果集数,限制提取的最大结果数有利于提供系统查询性能
*/
public IndexResultSet(Hits hits, int start, int count, int totalLimit){
results = new ArrayList();
page = PaginationUtils.create();
hitsLength = hits.length();
if(hitsLength > totalLimit){
total = totalLimit;
}else{
total = hitsLength;
}
int pageSize = count;
if(start + count > total){
count = total - start;
}
page.init( start, count, total, pageSize );
int end = start + count;
try{
Document doc;
for (int i = start; i < end; i++) {
doc = hits.doc( i );
Iterator iter = doc.getFields().iterator();
EMap data = new EMap();
String name, value, lvalue;
while(iter.hasNext()){
Field f = (Field)iter.next();
name = f.name();
value = doc.get(name);
data.setValue( name, value );
}
data.setValue( "score__", hits.score( i ) );
data.setValue( "docid__", hits.id( i ) );
results.add( data );
}
}catch(IOException ex){
throw new IndexException("索引结果集获取出错", ex);
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: