本篇文章給大家分享的是有關(guān)如何在asp.net項(xiàng)目中使用三層實(shí)現(xiàn)多條件檢索,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
成都創(chuàng)新互聯(lián)專注于洮南企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站建設(shè),成都商城網(wǎng)站開發(fā)。洮南網(wǎng)站建設(shè)公司,為洮南等地區(qū)提供建站服務(wù)。全流程按需定制,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)眾所周知,三層將項(xiàng)目分為界面層,業(yè)務(wù)邏輯層和數(shù)據(jù)訪問層(以最基本的三層為例)
同樣都知道,多條件檢索其實(shí)就是根據(jù)用戶選擇的條件項(xiàng),然后來拼sql語句
那么,既然要根據(jù)用戶選擇的條件項(xiàng)來拼sql語句,就肯定要在界面層接收用戶的選擇,這時(shí)候問題來了:
我是要在界面層拼sql語句嗎,這么做完全沒問題,功能也完全可以實(shí)現(xiàn),可是這么一來,你是破壞了三層的原則了嗎
那么還架三層做什么?
那我在數(shù)據(jù)訪問層拼sql語句好了,然后問題又來了:
在數(shù)據(jù)訪問層拼的話這么知道用戶選擇了哪幾個(gè)條件項(xiàng)呢,根據(jù)分層的原則,是不能把諸如textBox1.Text這樣的數(shù)據(jù)傳給數(shù)據(jù)訪問層的
其實(shí)解決的方案就是第二種方式,只是中間通過一個(gè)條件模型類來傳遞用戶的選擇
條件模型類如下:
public class SearchModel { public string Name { get; set; }//記錄數(shù)據(jù)庫字段名 public string Value { get; set; }//記錄對(duì)應(yīng)的值 public Action Action { get; set; }//記錄相應(yīng)的操作 }
選擇很難看出這個(gè)類的作用到底是什么,接著走你~
之后要準(zhǔn)備一個(gè)枚舉:
public enum Action { Lessthan, Greatthan, Like, Equart }
對(duì)應(yīng)數(shù)據(jù)中中的幾個(gè)操作,如<,>,like,=等,可以根據(jù)自己的需要添加
當(dāng)然你也可以用數(shù)字,不過魔鬼數(shù)字好不要使用,所以還是定義一個(gè)枚舉吧~動(dòng)動(dòng)手指頭就ok了
假設(shè)現(xiàn)在要對(duì)一個(gè)圖書表進(jìn)行多條件檢索
在界面層中的代碼:
Listss = new List (); if (!string.IsNullOrEmpty(Request.Form["txtName"]))//如果用戶在名字框中輸入了文字 { SearchModel model = new SearchModel(); model.Name = "BookName";//要操作的字段為書名 model.Value = Request.Form["txtName"];//對(duì)應(yīng)的值為用戶輸入的文字 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);//這里調(diào)用Bll進(jìn)行操作
Bll就先不說,主要是Dal層的sql拼接
public ListSearch(List ss)//接收傳進(jìn)來的條件模型類集合,并對(duì)其進(jìn)行遍歷 { 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語句傳入,開始查詢數(shù)據(jù)庫 foreach (DataRow row in table.Rows) { T_Books book = GetModelByDataRow.GetBooks(row); list.Add(book); } return list;//返回符合條件的圖書集合,完成
假設(shè)用戶輸入下圖的條件:
最后貼上測試拼接的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
以上就是如何在asp.net項(xiàng)目中使用三層實(shí)現(xiàn)多條件檢索,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。