Lucene查询结果Hits的二次封装
2008-08-04 12:58
513 查看
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);
}
}
/**
* 索引分页对象
*/
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);
}
}
相关文章推荐
- Lucene查询结果Hits的二次封装
- JDBC事务及将查询结果封装成对象(通用)
- 把对数据库的查询结果封装在List中
- lucene: 格式化值, 用于索引和索引查询条件以及查询结果
- Lucene的多域查询、结果中查询、查询结果分页、高亮查询结果和结果评分
- java_jdbc_反射技术将查询结果封装为对象
- 利用Boost影响Lucene查询结果的排序
- 分页查询产品信息,第六步;封装结果
- 从Object对象中封装了其它对象,怎样取出呢?(Hibernate查询结果处理)
- 利用反射技术将查询结果封装为对象
- Lucene的多域查询、结果中查询、查询结果分页、高亮查询结果和结果评分
- MyBatis查询结果封装成List
- LuceneSearch 现在要对查询结果进行排序的显示。
- 如何使用lucene.net,建立索引,索引目录,查询返回结果
- Oracle将某字段查询结果按自定义格式封装输出以及解拆操作
- Lucene的多域查询、结果中查询、查询结果分页、高亮查询结果和结果评分
- Lucene查询结果高亮
- Hibernate中使用sql查询结果后再封装成实体类的问题
- MySql中一次查询结果用作二次查询条件
- MySql中一次查询结果用作二次查询条件