在大型电子商务网站中,在商品列表页,咱们均可以看到商品按分类,品牌,价格的分类显示,以下图,这些咱们能够使用solr中的facet功能实现。网站
facet的基本功能就是对搜索结果中的商品进行分类。spa
1.facet用法xml
facet.field:指定要分类的字段索引
facet=on 或 facet=true表示功能开启ci
facet.prefix 表示字段前缀文档
facet.limit 表示返回的记录数产品
facet.offict 表示从第几条开始,主要用于分页it
facet.query能够任意定义查询class
注:用于facet的字段的索引index必定要设为true配置
2..facet.field
这里咱们查询产品名称中包含白色的商品有哪些分类,而且知道每一个分类有几条记录
把查询条件q=白色 facet.field=CategoryName,将获得下图结果
能够看到分类T桖中有两个商品名称中包括白色
分类裤子中有1个商品包括白色
3. 按价格进行分段查询
能够按价格区间来对搜索结果中的商品进行分段。咱们先看下怎么进行分段,打开solrconfig.xml配置,找到以下节点
<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条记录 ,查询的时候下限包括等于这种状况
facet还有其余参数用法,你们能够参照下官方文档。