前言 如果你在系統中用到了Solr的話,那麼肯定會碰到從Solr中反推數據的需求,基於資料庫數據生產索引後,那麼Solr索引的數據相對準確,在電商需求中經常會碰到菜單、導航分類(比如電腦、PC的話會有很多品牌)、新車二手車導航會有車的品牌。還會根據價格區間自由組合組成自定義查詢條件。常用高級用法如下 ...
前言
如果你在系統中用到了Solr的話,那麼肯定會碰到從Solr中反推數據的需求,基於資料庫數據生產索引後,那麼Solr索引的數據相對準確,在電商需求中經常會碰到菜單、導航分類(比如電腦、PC的話會有很多品牌)、新車二手車導航會有車的品牌。還會根據價格區間自由組合組成自定義查詢條件。常用高級用法如下:
1、根據基礎數據反推數據分類用於導航(電腦品牌、手機品牌、車的品牌)。
2、數據量大的要分頁。
3、自定義價格區間。
4、時間段分組。
5、高亮。
以下我羅列三個我遇到的實際問題用來演示下SolrNet的實際用法。
高級查詢場景一(Facet 查詢)
在賣車類電商網站中,你選擇了指定城市,那麼你肯定只想在查詢條件中查詢出該城市已有車源的品牌,這樣用戶選擇的查詢條件就是有效的。這裡用到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