说到分组统计估计你们都不会陌生,就是数据库的group by语句,可是当咱们采用solr4.5全文检索时,数据库提供再好的sql语句都没有任何的意义了,那么在solr4.5中咱们如何作到分组统计呢?其实很简单,下面咱们来看看怎么作。html
示例场景:sql
如今有个电子商务网站的产品搜索功能,不一样的商家发布不一样的产品,咱们想经过关键词“手机”去查找不一样商家下面有多少有关手机的产品。假设索引库的结构是产品id(id)、产品标题(title)、产品价格(price)、商家id(companyId)。数据库
如下示例采用slorj分组统计solr:网站
一、建立一个SolrServerspa
SolrServer server = new HttpSolrServer("http://127.0.0.1:2001/solr/product");
二、分组查询server
SolrQuery solrQuery = new SolrQuery("title:手机"); solrQuery.setParam("group", true);//是否分组 solrQuery.setParam("group.field", "companyId");//分组的域(此处以公司id进行分组) //solrQuery.setParam("group.query", "price:[0 TO 100]");//还能够根据其余条件进行过滤,如价格在1到100之间 solrQuery.setParam("group.limit", "10");//每组显示的个数,默认为1 solrQuery.setParam("group.ngroups", true);//是否计算所得分组个数;注意:当每一个分组显示数目大于1个时,不能用分组数量来计算总页码 //solrQuery.setStart(0); //起始索引值 //solrQuery.setRows(100);//显示几条数据 QueryResponse resp = server.query(solrQuery); GroupResponse gresp = resp.getGroupResponse();//注意:此处不能再用resp.getResults()接收结果 List<GroupCommand> commands = gresp.getValues(); if(commands != null) { for(GroupCommand com : commands) { Sysout.out.println("总的分组个数:" + com.getNGroups().longValue()); for(Group group : com.getValues()) { SolrDocumentList hits = group.getResult(); for(SolrDocument doc : hits) { System.out.println("id: " + (String)doc.getFieldValue("id") + ", title: " + (String)doc.getFieldValue("title") + ", price: " + (Float)doc.getFieldValue("price")); } } } }
三、实际的应用htm
相信使用过淘宝搜索功能的人都会注意到一个细小却又很重要的功能–“合并卖家”,若是使用solr就能够采用分组功能来实现。淘宝截图:索引
本文出自 luoshengsha.com,欢迎转载,转载时请注明出处及相应连接。get
本文永久连接: http://www.luoshengsha.com/319.html产品