wuliws 发表于 2016-12-15 08:56:52

solr分组聚合

  在大型电子商务网站中,在商品列表页,我们都可以看到商品按分类,品牌,价格的分类显示,如下图,这些我们可以使用solr中的facet功能实现。
    
facet的基本功能就是对搜索结果中的商品进行分类。
    1.facet用法
       facet.field:指定要分类的字段
       facet=on 或 facet=true表示功能开启
       facet.prefix 表示字段前缀
       facet.limit 表示返回的记录数
       facet.offict 表示从第几条开始,主要用于分页
       facet.query可以任意定义查询
    注:用于facet的字段的索引index一定要设为true
      2..facet.field
这里我们查询产品名称中包含白色的商品有哪些分类,并且知道每个分类有几条记录
        把查询条件q=白色     facet.field=CategoryName,将得到下图结果
         可以看到分类T桖中有两个商品名称中包括白色
             分类裤子中有1个商品包括白色
         
       
       3. 按价格进行分段查询
可以按价格区间来对搜索结果中的商品进行分段。我们先看下怎么进行分段,打开solrconfig.xml配置,找到如下节点
                      
 view plaincopy 



[*]<requestHandler class="solr.SearchHandler" name="/select">  
[*]<lst name="defaults">  
[*]<str name="echoParams">explicit</str>  
[*]<int name="rows">10</int>  
[*]<str name="df">text</str>  
[*]  
[*]str name="facet">on</str>  
[*]<str name="facet.range">Price</str>  
[*]<int name="f.Price.facet.range.start">0</int>  
[*]<int name="f.Price.facet.range.end">5000</int>  
[*]<int name="f.Price.facet.range.gap">1000</int>  
[*]</lst>  
[*]</requestHandler>  

        facet.range节点中表示按范围分段的字段为Price
        f.Price.facet.range.start表示起始值为0
       f.Price.facet.range.end表示最大值为 5000
       f.Price.facet.range.gap表示每次间隔1000进行分段 ,
      最后,我们看到的结果如下图
        0<=Price<1000 有1条记录
       1000<=Price<2000 有2条记录 ,查询的时候下限包括等于这种情况
      
    
           
 view plaincopy 



[*]   

    facet还有其他参数用法,大家可以参照下官方文档。
 
  转载自:http://blog.csdn.net/zx13525079024/article/details/26376697
页: [1]
查看完整版本: solr分组聚合