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配置,找到如下节点

                      

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. <requestHandler class="solr.SearchHandler" name="/select">  
  2. <lst name="defaults">  
  3. <str name="echoParams">explicit</str>  
  4. <int name="rows">10</int>  
  5. <str name="df">text</str>  
  6.   
  7. str name="facet">on</str>  
  8. <str name="facet.range">Price</str>  
  9. <int name="f.Price.facet.range.start">0</int>  
  10. <int name="f.Price.facet.range.end">5000</int>  
  11. <int name="f.Price.facet.range.gap">1000</int>  
  12. </lst>  
  13. </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条记录 ,查询的时候下限包括等于这种情况

      

    

           

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1.    

    facet还有其他参数用法,大家可以参照下官方文档。

 

转载自:http://blog.csdn.net/zx13525079024/article/details/26376697

猜你喜欢

转载自jlk.iteye.com/blog/2171264