关于solr的分组查询

最近再用apache的solr,觉得很好用现在想要用它实现一个分组查询不知道该怎么弄希望各位指点下... 最近再用apache的solr,觉得很好用
现在想要用它实现一个分组查询
不知道该怎么弄
希望各位指点下
展开
 我来答
LSIL
2009-08-20 · TA获得超过1127个赞
知道小有建树答主
回答量:1162
采纳率:0%
帮助的人:639万
展开全部
public static Map<String, Integer> queryByGroup(String qStr,String groupField,String sortField,boolean asc,Integer pageSize,Integer pageNum){
Map<String, Integer> rmap = new LinkedHashMap<String, Integer>();
try {
SolrServer server = getSolrServer();//getSolrServer() 方法就是返回一个CommonsHttpSolrServer
SolrQuery query = new SolrQuery();
if(qStr!=null&&qStr.length()>0)
query.setQuery(qStr);
else
query.setQuery("*:*");//如果没有查询语句,必须这么写,否则会报异常
query.setIncludeScore(false);//是否按每组数量高低排序
query.setFacet(true);//是否分组查询
query.setRows(0);//设置返回结果条数,如果你时分组查询,你就设置为0
query.addFacetField(groupField);//增加分组字段
query.setFacetSort(true);//分组是否排序
query.setFacetLimit(pageSize);//限制每次返回结果数
query.setSortField(sortField,asc ? SolrQuery.ORDER.asc :SolrQuery.ORDER.desc );//分组排序字段
query.set(FacetParams.FACET_OFFSET,(pageNum-1)*pageSize);//当前结果起始位置
QueryResponse rsp = server.query( query );

List<Count> countList = rsp.getFacetField(groupField).getValues();
List<Count> returnList = new ArrayList<Count>();
if(pageNum*pageSize<countList.size())
returnList = countList.subList((pageNum-1)*pageSize,pageNum*pageSize);
else
returnList = countList.subList((pageNum-1)*pageSize,countList.size()-1);

for (Count count : returnList) {
if(count.getCount()>0)
rmap.put(count.getName(), (int) count.getCount());
}
} catch (Exception e) {
e.printStackTrace();
}
return rmap;
}
帐号已注销
2009-08-20 · TA获得超过460个赞
知道小有建树答主
回答量:651
采纳率:0%
帮助的人:276万
展开全部
期待高手出现
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xdreamx
2009-08-20 · TA获得超过539个赞
知道小有建树答主
回答量:1250
采纳率:0%
帮助的人:543万
展开全部
在这里没用
到论坛去问问吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式