08、Solr速成之FacetPivot
什么是Facet.pivot
Facet.pivot就是按照多个维度进行分组查询,是Facet的加强,在实际运用中经常用到, 一个典型的例子就是商品目录树
NamedList解释:
NamedList,一个有序的name/value容器,NamedList不像Map,他具有以下特点:
1、 名字可以重复;
2、 NamedList中的element保持这有序状态;
3、 可以下标的形式访问Elements;
4、 name和value都可以为null;
package com.liucheng.solr;
import java.io.IOException;
import java.util.List;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrRequest;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrClient;
import org.apache.solr.client.solrj.response.PivotField;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.common.util.NamedList;
public class FacetPivot {
public static void facetPivotQuery(){
HttpSolrClient server = solrServer.getServer();
SolrQuery query = new SolrQuery();
String para = "*:*";
query.setFacet(true);
query.add("facet.pivot", "major_s,subMajor_s,brand_s");//多维度分组查询
query.setFacetLimit(100);//限制facet返回数量
query.setQuery(para);
try {
QueryResponse queryResponse = server.query(query,SolrRequest.METHOD.POST);
NamedList<List<PivotField>> namedList = queryResponse.getFacetPivot();
if(namedList != null){
List<PivotField> pivotList = null;
for(int i=0;i<namedList.size();i++){
pivotList = namedList.getVal(i);
if(pivotList != null){
for(PivotField pivot : pivotList){
System.out.println("一级:"+pivot.getValue()+" "+pivot.getCount());
List<PivotField> fieldList = pivot.getPivot();
if(fieldList!=null){
for(PivotField field : fieldList){
System.out.println("2级:"+field.getValue()+" "+field.getCount());
List<PivotField> fieldList1 = field.getPivot();
if(fieldList1!=null){
for(PivotField field1 : fieldList1){
System.out.println("3级:"+field1.getValue()+" "+field1.getCount());
}
}
}
}
}
}
}
}
} catch (SolrServerException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
facetPivotQuery();
}
}
一级:无敌电器 1
2级:无敌显示器 1
3级:无敌海尔儿 1
一级:电器 1
2级:显示器 1
3级:海尔儿 1
一级:超级电器 1
2级:超级显示器 1
3级:超级海尔儿 1