校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > asp.net用三層實現多條件檢索示例

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

熱門標簽:征途美甲店地圖標注 昆明語音電銷機器人價格 浦發電話機器人提醒還款 百度地圖怎樣做地圖標注 騰訊地圖標注手機 電銷語音機器人型號參數 400電話如何申請取消 太原400電話上門辦理 柳州電銷機器人公司

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

同樣都知道,多條件檢索其實就是根據用戶選擇的條件項,然后來拼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了

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

在界面層中的代碼:

ListSearchModel> ss = new ListSearchModel>(); 
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); 
} 
ListT_Books> books = searchBll.Searc(ss);//這里調用Bll進行操作

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

public ListT_Books> Search(ListSearchModel> 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 "; 
} 
} 
ListT_Books> list = new ListT_Books>(); 
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;//返回符合條件的圖書集合,完成

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

最后貼上測試拼接的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 在三層架構中事務的使用實例代碼
  • 擴展ASP.NET MVC三層框架且使用StructureMap實現依賴注入1-Model層
  • asp.net實現三層架構的例子
  • ASP.NET MVC5 網站開發框架模型、數據存儲、業務邏輯(三)
  • ASP.NET創建三層架構圖解詳細教程
  • 在ASP.NET 2.0中操作數據之一:創建一個數據訪問層
  • 在ASP.NET 2.0中操作數據之二:創建一個業務邏輯層

標簽:新疆 天門 張家界 江蘇 白山 德陽 蘭州 陽泉

巨人網絡通訊聲明:本文標題《asp.net用三層實現多條件檢索示例》,本文關鍵詞  asp.net,用,三層,實現,多,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp.net用三層實現多條件檢索示例》相關的同類信息!
  • 本頁收集關于asp.net用三層實現多條件檢索示例的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    99久久精品国产精品久久| 美女视频一区二区三区| 亚州成人在线电影| 国产xxx精品视频大全| 欧美日韩国产影片| 国产精品麻豆久久久| 精品一区二区影视| 欧美亚洲国产一区二区三区va| 久久这里只有精品视频网| 亚洲嫩草精品久久| 国产精品一区二区在线观看不卡| 欧美久久一二区| 亚洲女子a中天字幕| 精品一区二区三区视频| 欧美日韩精品二区第二页| 国产精品久久久久影院| 国产麻豆视频一区| 欧美疯狂性受xxxxx喷水图片| 亚洲色图一区二区| 国产不卡视频一区二区三区| 久久综合狠狠综合久久综合88| 日韩电影免费在线| 欧美日韩在线一区二区| 《视频一区视频二区| 国产成人精品影视| 欧美精选一区二区| 国产精品国产三级国产普通话蜜臀 | 一区二区激情视频| 国产一本一道久久香蕉| 日韩视频在线永久播放| 亚洲最新在线观看| 91久久香蕉国产日韩欧美9色| 国产精品国产精品国产专区不蜜| 国产美女娇喘av呻吟久久| 精品对白一区国产伦| 美女精品自拍一二三四| 日韩欧美电影一区| 麻豆免费精品视频| 欧美mv和日韩mv国产网站| 麻豆久久一区二区| 日韩欧美在线1卡| 精彩视频一区二区| 精品国产网站在线观看| 国产美女精品人人做人人爽| 国产日韩综合av| av影院午夜一区| 一区二区三区中文字幕精品精品 | 欧美性受极品xxxx喷水| 亚洲国产美女搞黄色| 色噜噜狠狠成人中文综合| 亚洲精品国产品国语在线app| 色噜噜狠狠成人网p站| 亚洲午夜日本在线观看| 欧美一区二区三级| 国产精品99久久久久久久vr| 国产精品理论在线观看| 在线观看免费亚洲| 蜜桃精品视频在线观看| 久久久国产一区二区三区四区小说| 粉嫩欧美一区二区三区高清影视 | 亚洲精品一区二区精华| 成人国产精品免费观看视频| 亚洲精品五月天| 欧美一区日韩一区| 国产成人啪免费观看软件| 一区二区在线观看不卡| 日韩欧美色电影| 91视频你懂的| 美日韩一区二区三区| 亚洲色图色小说| 欧美丰满美乳xxx高潮www| 国产成人免费av在线| 亚洲成年人影院| 国产三级一区二区| 欧美色窝79yyyycom| 国产麻豆9l精品三级站| 一级做a爱片久久| 欧美精品一区二区三区久久久| 99久久精品免费看| 蜜臀av一级做a爰片久久| 综合av第一页| 国产三级一区二区三区| 91精品国产入口| 日本高清视频一区二区| 亚洲高清久久久| 国产精品第13页| 精品久久久网站| 欧美在线观看视频一区二区| 亚洲天堂免费看| 欧美丰满美乳xxx高潮www| 久久久一区二区三区| av在线播放成人| 欧美在线色视频| 成人午夜免费av| 亚洲男人天堂一区| 国产99久久久国产精品潘金网站| 中文字幕一区二区三区视频| 欧美日韩免费电影| 视频一区视频二区中文字幕| 国产精品网站在线播放| 色8久久精品久久久久久蜜| 亚洲欧美在线另类| 色94色欧美sute亚洲线路一ni| 久久精品视频在线看| 成人av中文字幕| 亚洲一区二区三区四区五区中文| 91国在线观看| 久久精品国产精品亚洲综合| 国产精品国产三级国产有无不卡| 91国偷自产一区二区三区观看| 亚洲成人午夜影院| 日韩一区二区三区视频| 国产精品99久久久久久久女警| 亚洲三级在线免费| 久久久蜜桃精品| 欧美一区二区三区播放老司机| 国产经典欧美精品| 偷拍一区二区三区四区| 成人欧美一区二区三区小说 | 欧美色图12p| 国产精品一二三四| 亚洲小说欧美激情另类| 日韩欧美精品在线视频| 91精品欧美综合在线观看最新| 国产老妇另类xxxxx| 亚洲午夜激情网页| 亚洲成a人v欧美综合天堂| 国产精品九色蝌蚪自拍| 成人免费视频app| 国产一区不卡视频| 国产一区二区不卡| 国产在线视视频有精品| 欧美亚洲精品一区| 男人的j进女人的j一区| 欧美日韩小视频| 国产乱理伦片在线观看夜一区| 国产精品亚洲人在线观看| 成人免费视频视频| 日本二三区不卡| 日韩欧美一二三| 国产精品乱码一区二区三区软件 | 精品少妇一区二区| 精品国产一区二区三区av性色| 精品精品国产高清a毛片牛牛| 欧美成人一区二区| 国产人成一区二区三区影院| 久久久五月婷婷| 视频一区在线播放| 欧美伊人久久大香线蕉综合69| 男女男精品视频网| 亚洲国产精品高清| 日韩一区国产二区欧美三区| 国产福利视频一区二区三区| 国产精品美女www爽爽爽| 国产成人综合在线播放| 欧美精品1区2区3区| 国产一区二区成人久久免费影院 | 国产精品久久久久久久岛一牛影视| 99视频有精品| 精品影院一区二区久久久| 亚洲色图一区二区| 日韩视频一区二区三区在线播放| 国产成人精品午夜视频免费| 亚洲一二三级电影| 国产精品污网站| 久久影音资源网| 欧美日韩一二三区| 99精品国产99久久久久久白柏| 日韩高清中文字幕一区| 亚洲欧美日韩中文字幕一区二区三区| 日韩一区二区免费视频| 欧美中文字幕一区| 99久久精品国产毛片| 成人中文字幕合集| 国产一区二区毛片| 综合久久久久久| 国产91高潮流白浆在线麻豆 | 菠萝蜜视频在线观看一区| 这里只有精品99re| 亚洲色图都市小说| 久久久亚洲欧洲日产国码αv| 国产在线一区二区| 久久精品国产亚洲高清剧情介绍 | 欧美综合久久久| 日本一区二区动态图| 91小视频在线观看| 欧美sm极限捆绑bd| 日本最新不卡在线| 欧美日韩精品免费观看视频| 亚洲九九爱视频| av动漫一区二区| 中文字幕国产一区二区| 国产一区二三区| 26uuu亚洲综合色欧美| 日本欧美一区二区在线观看| 欧美日韩精品一区视频| 亚洲高清免费一级二级三级| 欧美日韩国产首页| 婷婷成人激情在线网| 欧美午夜寂寞影院|