dryu999 发表于 2017-12-19 20:23:34

指尖上的电商

  在大型电子商务站点中,在商品列表页,我们都能够看到商品按分类,品牌,价格的分类显示,例如以下图,这些我们能够使用solr中的facet功能实现。

  facet的基本功能就是对搜索结果中的商品进行分类。
  1.facet使用方法
  
facet.field:指定要分类的字段

  facet=on 或>  facet.prefix 表示字段前缀
  >  facet.offict 表示从第几条開始,主要用于分页
  facet.query能够随意定义查询
  注:用于facet的字段的索引index一定要设为true
  2..facet.field
  这里我们查询产品名称中包括白色的商品有哪些分类,而且知道每一个分类有几条记录
  把查询条件q=白色   
facet.field=CategoryName,将得到下图结果
  能够看到分类T桖中有两个商品名称中包含白色
  分类裤子中有1个商品包含白色

  3. 按价格进行分段查询
  能够按价格区间来对搜索结果中的商品进行分段。我们先看下怎么进行分段。打开solrconfig.xml配置,找到例如以下节点
  

<requestHandler>
<lst name=&quot;defaults&quot;>
  
<str name=&quot;echoParams&quot;>explicit</str>
  
<int name=&quot;rows&quot;>10</int>
  
<str name=&quot;df&quot;>text</str>
  

  
str name=&quot;facet&quot;>on</str>
  
<str name=&quot;facet.range&quot;>Price</str>
  
<int name=&quot;f.Price.facet.range.start&quot;>0</int>
  
<int name=&quot;f.Price.facet.range.end&quot;>5000</int>
  
<int name=&quot;f.Price.facet.range.gap&quot;>1000</int>
  
</lst>
  
</requestHandler>
  


  >  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条记录 ,查询的时候下限包含等于这样的情况

  

  


  >
页: [1]
查看完整版本: 指尖上的电商