在大型電子商務網站中,在商品列表頁,咱們均可以看到商品按分類,品牌,價格的分類顯示,以下圖,這些咱們能夠使用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還有其餘參數用法,你們能夠參照下官方文檔。