程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> 關於ASP.NET >> asp.net用三層實現多條件檢索示例

asp.net用三層實現多條件檢索示例

編輯:關於ASP.NET

       三層將項目分為界面層,業務邏輯層和數據訪問層,下面為大家介紹下asp.net如何用三層實現多條件檢索,感興趣的朋友可以參考下

      眾所周知,三層將項目分為界面層,業務邏輯層和數據訪問層(以最基本的三層為例)

      同樣都知道,多條件檢索其實就是根據用戶選擇的條件項,然後來拼sql語句

      那麼,既然要根據用戶選擇的條件項來拼sql語句,就肯定要在界面層接收用戶的選擇,這時候問題來了:

      我是要在界面層拼sql語句嗎,這麼做完全沒問題,功能也完全可以實現,可是這麼一來,你是破壞了三層的原則了嗎

      那麼還架三層做什麼?

      那我在數據訪問層拼sql語句好了,然後問題又來了:

      在數據訪問層拼的話這麼知道用戶選擇了哪幾個條件項呢,根據分層的原則,是不能把諸如textBox1.Text這樣的數據傳給數據訪問層的

      其實解決的方案就是第二種方式,只是中間通過一個條件模型類來傳遞用戶的選擇

      條件模型類如下:

      public class SearchModel

      {

      public string Name { get; set; }//記錄數據庫字段名

      public string Value { get; set; }//記錄對應的值

      public Action Action { get; set; }//記錄相應的操作

      }

      選擇很難看出這個類的作用到底是什麼,接著走你~

      之後要准備一個枚舉:

      public enum Action

      {

      Lessthan,

      Greatthan,

      Like,

      Equart

      }

      對應數據中中的幾個操作,如<,>,like,=等,可以根據自己的需要添加

      當然你也可以用數字,不過魔鬼數字最好不要使用,所以還是定義一個枚舉吧~動動手指頭就ok了

      假設現在要對一個圖書表進行多條件檢索

      在界面層中的代碼:

      List ss = new List();

      if (!string.IsNullOrEmpty(Request.Form["txtName"]))//如果用戶在名字框中輸入了文字

      {

      SearchModel model = new SearchModel();

      model.Name = "BookName";//要操作的字段為書名

      model.Value = Request.Form["txtName"];//對應的值為用戶輸入的文字

      model.Action = Action.Like;//操作為like

      ss.Add(model);

      }//以下類似

      if (!string.IsNullOrEmpty(Request.Form["txtAuthor"]))

      {

      SearchModel model = new SearchModel();

      model.Name = "Author";

      model.Value = Request.Form["txtAuthor"];

      model.Action = Action.Like;

      ss.Add(model);

      }

      if (!string.IsNullOrEmpty(Request.Form["categoryId"]))

      {

      SearchModel model = new SearchModel();

      model.Name = "CategoryId";

      model.Value = Request.Form["categoryId"];

      model.Action = Action.Equart;

      ss.Add(model);

      }

      if (!string.IsNullOrEmpty(Request.Form["publisherId"]))

      {

      SearchModel model = new SearchModel();

      model.Name = "PublisherId";

      model.Value = Request.Form["publisherId"];

      model.Action = Action.Equart;

      ss.Add(model);

      }

      if (!string.IsNullOrEmpty(Request.Form["txtISBN"]))

      {

      SearchModel model = new SearchModel();

      model.Name = "ISBN";

      model.Value = Request.Form["txtISBN"];

      model.Action = Action.Like;

      ss.Add(model);

      }

      if (!string.IsNullOrEmpty(Request.Form["isDiscount"]))

      {

      SearchModel model = new SearchModel();

      model.Name = "Discount";

      model.Value = "1";

      model.Action = Action.Equart;

      ss.Add(model);

      }

      List books = searchBll.Searc(ss);//這裡調用Bll進行操作

      Bll就先不說,主要是Dal層的sql拼接

      public List Search(List ss)//接收傳進來的條件模型類集合,並對其進行遍歷

      {

      string sql = "select * from T_Books where IsDelete=0 and ";//開始拼接sql語句

      for (int i = 0; i < ss.Count; i++)

      {

      if (ss[i].Action == Action.Like)

      {

      sql += ss[i].Name + " like '%" + ss[i].Value + "%'";

      }

      if (ss[i].Action == Action.Equart)

      {

      sql += ss[i].Name + " = " + ss[i].Value;

      }

      if (ss[i].Action == Action.Greatthan)

      {

      sql += ss[i].Name + " > " + ss[i].Value;

      }

      if (ss[i].Action == Action.Lessthan)

      {

      sql += ss[i].Name + " < " + ss[i].Value;

      }

      if (i != ss.Count - 1)

      {

      sql += " and ";

      }

      }

      List list = new List();

      DataTable table = SqlHelper.ExecuteDataTable(sql, CommandType.Text);//將拼接好的sql語句傳入,開始查詢數據庫

      foreach (DataRow row in table.Rows)

      {

      T_Books book = GetModelByDataRow.GetBooks(row);

      list.Add(book);

      }

      return list;//返回符合條件的圖書集合,完成

      假設用戶輸入下圖的條件:

    asp.net用三層實現多條件檢索示例  三聯

      最後貼上測試拼接的sql語句,如下

      select * from T_Books where IsDelete=0 and BookName like '%C++%' and Author like '%JChubby%' and CategoryId = 15 and PublisherId = 16 and ISBN like '%1111%' and Discount = 1

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