1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關(guān)咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務(wù)時間:8:30-17:00
      你可能遇到了下面的問題
      關(guān)閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
      DapperExtensions和反射實(shí)現(xiàn)通用搜索的方法

      這篇文章主要介紹了DapperExtensions和反射實(shí)現(xiàn)通用搜索的方法,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

      成都創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)服務(wù)商,為中小企業(yè)提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)服務(wù),網(wǎng)站設(shè)計(jì),成都網(wǎng)站托管等一站式綜合服務(wù)型公司,專業(yè)打造企業(yè)形象網(wǎng)站,讓您在眾多競爭對手中脫穎而出成都創(chuàng)新互聯(lián)公司。

      前言

      搜索功能是一個很常用的功能,當(dāng)然這個搜索不是指全文檢索,是指網(wǎng)站的后臺管理系統(tǒng)或ERP系統(tǒng)列表的搜索功能。常見做法一般就是在搜索欄上加上幾個常用字段來搜索。代碼可能一般這樣實(shí)現(xiàn)

      StringBuilder sqlStr = new StringBuilder();
      if (!string.IsNullOrEmpty(RealName))
      {
        sqlStr.Append(" and RealName = @RealName");
      }
      if (Age != -1)
      {
        sqlStr.Append(" and Age = @Age");
      }
      if (!string.IsNullOrEmpty(StartTime))
      {
        sqlStr.Append(" and CreateTime >= @StartTime");
      }
      if (!string.IsNullOrEmpty(EndTime))
      {
        sqlStr.Append(" and CreateTime <= @EndTime");
      }
      MySQLParameter[] paras = new MySqlParameter[]{
            new MySqlParameter("@Age", Age),
            new MySqlParameter("@RealName", RealName),
            new MySqlParameter("@StartTime", StartTime),
            new MySqlParameter("@EndTime", EndTime)
          };

      這段代碼如果遇到下面幾個需求,又該如何處理?

      1. 再加一個查詢字段

      2. RealName需要改成模糊查詢

      3. Age需要支持范圍查詢

      可能大多數(shù)程序猿想法,這是新的需求,那么就直接改代碼,簡單粗暴。然后在前臺加個age范圍文本框,后臺再加個if判斷,realname的=號就直接改成like,就這樣輕松搞定了。但需求總是不斷變化,如果一張表有50個字段,同時需要支持其中40個字段查詢。我想大都數(shù)人第一反應(yīng):臥槽,神經(jīng)病!難道就沒有一個通用的辦法來解決這種搜索的問題?我想說當(dāng)然有,本文接下來就用DapperExtensions和反射的來解決這個問題,最終于實(shí)現(xiàn)的效果如下圖:

      DapperExtensions和反射實(shí)現(xiàn)通用搜索的方法

      DapperExtensions介紹

      DapperExtensions是基于Dapper的一個擴(kuò)展,主要在Dapper基礎(chǔ)上實(shí)現(xiàn)了CRUD的操作。它還提供了一個謂詞系統(tǒng),可以實(shí)現(xiàn)更多復(fù)雜的高級查詢功能。還可以通過ClassMapper來定義實(shí)體類和表的映射。

      通用搜索功能實(shí)現(xiàn)

      1.首先創(chuàng)建一個account表,然后增加一個Account類

      public class Account
        {
          public Account()
          {
            Age = -1;
          }
          /// 
          /// 賬戶ID
          /// 
          [Mark("賬戶ID")]
          public int AccountId { get; set; }
          /// 
          /// 姓名
          /// 
          [Mark("姓名")]
          public string RealName { get; set; }
          /// 
          /// 年齡
          /// 
          [Mark("年齡")]
          public int Age { get; set; }
          /// 
          /// 創(chuàng)建時間
          /// 
          [Mark("創(chuàng)建時間")]
          public DateTime CreateTime { get; set; }
        }

      2.為了獲取字段對應(yīng)的中文名稱,我們增加一個MarkAttribute類。因?yàn)橛袕?qiáng)大的反射功能,我們可以通過反射動態(tài)獲取每張表實(shí)體類的屬性和中文名稱。

      [AttributeUsage(AttributeTargets.Property, Inherited = false, AllowMultiple = true)]
        public class MarkAttribute : Attribute
        {
          public MarkAttribute(string FiledName, string Description = "")
          {
            this.FiledName = FiledName;
            this.Description = Description;
          }
          private string _FiledName;
          public string FiledName
          {
            get { return _FiledName; }
            set { _FiledName = value; }
          }
          private string _Description;
          public string Description
          {
            get { return _Description; }
            set { _Description = value; }
          }
        }

      3.通用搜索思路主要是把搜索功能抽象出一個對象,本質(zhì)上也就列名、操作符、值組成的一個對象集合,這樣就可以實(shí)現(xiàn)多個搜索條件的組合。我們增加一個Predicate類

      public class Predicate
        {
          /// 
          /// 列名
          /// 
          public string ColumnItem { get; set; }
          /// 
          /// 操作符
          /// 
          public string OperatorItem { get; set; }
          /// 
          /// 值
          /// 
          public object Value { get; set; }
        }

      4.然后通過反射Account類的屬性加載到前臺列名的DropDownList,再增加一個操作符的DropDownList

      var columnItems = new List();
            //通過反射來獲取類的屬性
            Type t = Assembly.Load("SearchDemo").GetType("SearchDemo.Models.Account");
            foreach (PropertyInfo item in t.GetProperties())
            {
              string filedName = (item.GetCustomAttributes(typeof(MarkAttribute), false)[0] as MarkAttribute).FiledName;
              columnItems.Add(new SelectListItem() { Text = filedName, Value = item.Name });
            }
            ViewBag.columnItems = columnItems;
            var operatorItems = new List()
            {
              new SelectListItem() {Text = "等于", Value = "Eq"},
              new SelectListItem() {Text = "大于", Value = "Gt"},
              new SelectListItem() {Text = "大于或等于", Value = "Ge"},
              new SelectListItem() {Text = "小于", Value = "Lt"},
              new SelectListItem() {Text = "小于或等于", Value = "Le"},
              new SelectListItem() {Text = "模糊", Value = "Like"}
            };
            ViewBag.operatorItems = operatorItems;

      5.前臺界面實(shí)現(xiàn)代碼

      
      
      
        DapperExtensions通用搜索
        
        
        
        
      
      
        

      列名:@Html.DropDownList("columnItems") 操作符:@Html.DropDownList("operatorItems") 值:@Html.TextBox("value")


      • 列名
      • 操作符
      • 操作


      • 賬戶ID
      • 姓名
      • 年齡
      • 創(chuàng)建時間

      6.最后通過DapperExtensions的謂詞和反射實(shí)現(xiàn)搜索方法

       [HttpPost]
          public JsonResult Search(List predicates)
          {
            if (predicates == null)
            {
              return Json(new { Error = "請?jiān)黾铀阉鳁l件" });
            }
            using (var connection = SqlHelper.GetConnection())
            {
              var pga = new PredicateGroup { Operator = GroupOperator.And, Predicates = new List() };
              foreach (var p in predicates)
              {
                var predicate = Predicates.Field(GetExpression(p), (Operator)Enum.Parse(typeof(Operator), p.OperatorItem), p.Value);
                pga.Predicates.Add(predicate);
              }
              var list = connection.GetList(pga);
              return Json(list);
            }
          }
          private static Expression> GetExpression(Predicate p)
          {
            ParameterExpression parameter = Expression.Parameter(typeof(Account), "p");
            return Expression.Lambda>(Expression.Convert(Expression.Property(parameter, p.ColumnItem), typeof(object)), parameter);
          }

      最終,通過簡單的幾行代碼,在基于DapperExtensions的功能基礎(chǔ)上,我們最終實(shí)現(xiàn)了一個可以支持多個字段、多個條件、多個操作符的通用查詢功能。本文也只是拋磚引玉,只是提供一種思路,還有更多細(xì)節(jié)沒有考慮。比如多個條件的組合可以再增加一個邏輯符來連接、多個條件組合嵌套查詢、多表查詢等等。

      感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享DapperExtensions和反射實(shí)現(xiàn)通用搜索的方法內(nèi)容對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián),詳細(xì)的解決方法等著你來學(xué)習(xí)!


      網(wǎng)頁名稱:DapperExtensions和反射實(shí)現(xiàn)通用搜索的方法
      路徑分享:http://ef60e0e.cn/article/podpdd.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        沂源县| 璧山县| 龙江县| 自贡市| 洞头县| 冕宁县| 翼城县| 宁南县| 于田县| 灵台县| 闸北区| 沐川县| 丹凤县| 镇安县| 深圳市| 黄骅市| 晴隆县| 宿松县| 湟源县| 水富县| 都昌县| 鄂托克前旗| 比如县| 饶河县| 庄河市| 宽城| 文成县| 北辰区| 融水| 宣汉县| 德格县| 阜宁县| 安福县| 古丈县| 罗城| 靖宇县| 铁力市| 南和县| 托里县| 诸城市| 金溪县|