程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> SolrNet高級用法(分頁、Facet查詢、任意分組),solrnetfacet

SolrNet高級用法(分頁、Facet查詢、任意分組),solrnetfacet

編輯:C#入門知識

SolrNet高級用法(分頁、Facet查詢、任意分組),solrnetfacet


前言

       如果你在系統中用到了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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved