solr研磨之facet
阿新 • • 發佈:2018-05-03
www. http local 參數 需要 想要 結果 域配置 例如
作者:戰鬥民族就是幹
轉載請註明地址:http://www.cnblogs.com/prayers/p/8822417.html
Facet
開門見山,facet解決的就是篩選,我是把它理解為一種聚合。
例如,商品屬性中的品牌名稱。例如:搜索召回了100個sku,這100個sku裏面包含在20個品牌裏面,那我如何聚合出這20個品牌呢?solr給我們提供了強大的API,facet,基本用例如下
http://localhost:8080/solr/b2b/select?q=*:*&wt=json&indent=true&facet=true&facet.field=brandName
這裏需要註意的是:如果brandName配置了分詞器,facet的結果是對域的域值分詞後得到的每一個唯一的詞進行分組統計。
facet不僅僅可以支持單值域的分組統計,還支持多值域,文本域,嵌入式facet的統計。需要註意的是:在進行文本域的facet的時候大量的噪音詞會影響你返回的結果,這時候需要對文本域配置停用詞過濾器
還有一種情況,比如說品牌名稱,我既需要查詢做分詞處理,又需要進行facet統計。但是分詞後facet的結果並不是我想要的,我想要的是不做分詞處理的facet的結果。這個時候我們可以使用復制域CopyField,將品牌名稱作為一個新域,並且是域的類型是StringFilter。copyField使用用例如下:
<copyField source="brandName" dest="copyBrandName" maxChars="30000" />
source:需要拷貝的域名稱
dest:被拷貝的域名稱
maxChars:限制復制的字符數
單個域的facet用例如下
http://localhost:8080/solr/b2b/select?q=*:*&wt=json&indent=true&facet=true&facet.field=brandName
多個域的facet用例如下
http://localhost:8080/solr/b2b/select?q=*:*&wt=json&indent=true&facet=true&facet.pivot=brandCode,brandName
區間facet
http://localhost:8080/solr/b2b/select?q=*%3A*&wt=json&indent=true&facet=true&facet.range=price&facet.range.gap=10&facet.range.start=0&facet.range.end=10000
facet.range:表示對那個域執行facet區間查詢,facet.range.start表示區間的上限值,facet.range.end表示區間的下限值,facet.range.gap:參數按照每個區間分布多少個值進行自動區間劃分
solr研磨之facet