如果你在系統中用到了Solr的話,那麼肯定會碰到從Solr中反推數據的需求,基於數據庫數據生產索引後,那麼Solr索引的數據相對准確,在電商需求中經常會碰到菜單、導航分類(比如電腦、PC的話會有很多品牌)、新車二手車導航會有車的品牌。還會根據價格區間自由組合組成自定義查詢條件。常用高級用法如下:
1、根據基礎數據反推數據分類用於導航(電腦品牌、手機品牌、車的品牌)。
2、數據量大的要分頁。
3、自定義價格區間。
4、時間段分組。
5、高亮。
以下我羅列三個我遇到的實際問題用來演示下SolrNet的實際用法。
在賣車類電商網站中,你選擇了指定城市,那麼你肯定只想在查詢條件中查詢出該城市已有車源的品牌,這樣用戶選擇的查詢條件就是有效的。這裡用到Solr的Facet語法,Facet我理解為分片或者分類查詢。用Facet Field查詢的結果則在返回值的FacetFields字段中,他會把所有品牌的id都羅列出來,返回一個KeyValue,結果中是返回所有的品牌和對應的車源數量。車源數量大於0的則是該地區對應的品牌數據。
ISolrOperations<SolrQuotePriceCore> solr = ServiceLocator.Current.GetInstance<ISolrOperations<SolrQuotePriceCore>>();
//查找城市
ISolrQuery q1 = new SolrQueryByField("provid", "540000"); //省份ID
ISolrQuery q2 = new SolrQueryByField("cityid", "542400"); //市ID
ISolrQuery q3 = new SolrQueryByField("selled", "1"); //在售狀態
IList<ISolrQuery> filter=new List<ISolrQuery>();
filter.Add(q1);
filter.Add(q2);
filter.Add(q3);
//分組
var facet = new FacetParameters()
{
Queries = new[]
{
new SolrFacetFieldQuery("brandid"),
}
};
QueryOptions options=new QueryOptions();
options.Facet = facet;
SolrMultipleCriteriaQuery qtbo = new SolrMultipleCriteriaQuery(filter,"AND");
SolrQueryResults<SolrQuotePriceCore> results = solr.Query(qtbo,options);
foreach (var f in results.FacetFields["brandId"])
{
if (f.Value > 0)
Console.WriteLine("{0}: {1}", f.Key, f.Value);
}
上面是車源品牌,價格也一樣,你想根據指定價格區間查詢車源數據則就要用到任務分組。 任意分組的查詢結果在返回值的FacetQueries中,遍歷改keyvalue取值。
ISolrOperations<SolrQuotePriceCore> solr = ServiceLocator.Current.GetInstance<ISolrOperations<SolrQuotePriceCore>>();
ISolrQuery r1 = new SolrQueryByRange<decimal>("price", 0, 3m);
ISolrQuery r2 = new SolrQueryByRange<decimal>("price", 3.01m, 5m);
ISolrQuery r3 = new SolrQueryByRange<decimal>("price", 5.01m, 8m);
ISolrQuery r4 = new SolrQueryByRange<decimal>("price", 8.01m, 10m);
ISolrQuery r5 = new SolrQueryByRange<decimal>("price", 10.01m, 15m);
ISolrQuery r6 = new SolrQueryByRange<decimal>("price", 15.01m, 20m);
ISolrQuery r7 = new SolrQueryByRange<decimal>("price", 20.01m, 30m);
ISolrQuery r8 = new SolrQueryByRange<decimal>("price", 30.01m, 50m);
ISolrQuery r9 = new SolrQueryByRange<decimal>("price", 50.01m, 1000m);
var facet = new FacetParameters()
{
Queries = new[]
{
new SolrFacetQuery(r1),
new SolrFacetQuery(r2),
new SolrFacetQuery(r3),
new SolrFacetQuery(r4),
new SolrFacetQuery(r5),
new SolrFacetQuery(r6),
new SolrFacetQuery(r7),
new SolrFacetQuery(r8),
new SolrFacetQuery(r9)
}
};
ISolrQuery q1 = new SolrQueryByField("provid", "540000");
ISolrQuery q2 = new SolrQueryByField("cityid", "542400");
ISolrQuery q3 = new SolrQueryByField("selled", "1");
IList<ISolrQuery> filter = new List<ISolrQuery>();
filter.Add(q1);
filter.Add(q2);
filter.Add(q3);
QueryOptions options=new QueryOptions();
options.Facet = facet;
var qTBO = new SolrMultipleCriteriaQuery(filter, "AND");
SolrQueryResults<SolrQuotePriceCore> results = solr.Query(qTBO, options);
foreach (var f in results.FacetQueries)
{
Console.WriteLine("{0}: {1}", f.Key, f.Value);
}
QueryOptions options = new QueryOptions(); //分頁參數 options.Rows = pageNum; //數據條數 options.Start = start; //開始項 // 拼接相關查詢條件 //執行查詢 SolrQueryResults<Product> results = solr.Query(qTBO, options); // 得到返回的數據總條數和total和 總頁數 用於分頁顯示, var total = results.NumFound; var pageCount = total / pageNum + 1;
查詢用到的接口和類ISolrQuery、SolrQueryByField、有多個查詢條件需要構造一個SolrMultipleCriteriaQuery類以及查詢條件之間的邏輯關系(AND、OR)。類似Facet、Sort、OrderBy、Highlight、SpellCheck都在QueryOptions裡。
http://www.cnblogs.com/zhangweizhong/p/5075277.html?utm_source=tuicool&utm_medium=referral