婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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用三層實現多條件檢索示例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    丁香天五香天堂综合| 亚洲综合在线免费观看| 精品人在线二区三区| 视频在线观看国产精品| 欧美色精品天天在线观看视频| 亚洲欧美另类久久久精品| av一区二区三区黑人| 亚洲欧美在线高清| 91在线精品一区二区三区| 亚洲人被黑人高潮完整版| 色狠狠桃花综合| 日韩av网站在线观看| 久久综合久久鬼色中文字| 国产成人精品亚洲日本在线桃色 | 最新国产精品久久精品| 成人国产一区二区三区精品| 亚洲精选免费视频| 欧美日韩亚洲另类| 日本中文在线一区| 欧美韩国日本一区| 91尤物视频在线观看| 亚洲影院在线观看| 久久久五月婷婷| 91麻豆自制传媒国产之光| 日韩中文字幕1| 国产精品青草综合久久久久99| 欧美日韩一区在线观看| 免费成人你懂的| 最新国产の精品合集bt伙计| 91精品综合久久久久久| 成人国产亚洲欧美成人综合网| 亚洲一区二区三区激情| 久久久91精品国产一区二区精品| 色综合久久久久综合体| 国内精品久久久久影院薰衣草| 亚洲欧美另类久久久精品| 日韩一级二级三级精品视频| 色综合天天综合给合国产| 老汉av免费一区二区三区| 亚洲欧美国产高清| 国产午夜三级一区二区三| 欧美狂野另类xxxxoooo| 99久久婷婷国产综合精品电影 | 久久久久久亚洲综合| 99久久精品国产一区二区三区| 蜜臀av性久久久久蜜臀aⅴ| 亚洲美女屁股眼交3| 久久精品免费在线观看| 日韩午夜在线影院| 91.com在线观看| 欧美在线观看你懂的| 成人毛片在线观看| 国产资源精品在线观看| 免费亚洲电影在线| 亚洲午夜一区二区| 亚洲青青青在线视频| 久久综合九色综合97婷婷| 日韩欧美一区中文| 欧美人伦禁忌dvd放荡欲情| 在线观看成人小视频| 99久久婷婷国产综合精品电影| 国产剧情在线观看一区二区| 美女视频黄 久久| 天天色天天操综合| 午夜精品久久久久久不卡8050| 一区二区三区精品视频| 亚洲综合色成人| 亚洲精品免费一二三区| 亚洲日本在线a| 亚洲欧美视频一区| 亚洲主播在线播放| 亚洲妇女屁股眼交7| 日韩精品一二区| 免费不卡在线视频| 国产自产视频一区二区三区| 国产一区二区久久| 国产伦精一区二区三区| 成人av免费网站| 欧美性生活影院| 日韩一区二区三区免费观看| 久久久久久久久免费| 中文av一区二区| 亚洲欧美一区二区三区国产精品| 亚洲成在人线在线播放| 日本在线播放一区二区三区| 久久成人18免费观看| 豆国产96在线|亚洲| 91尤物视频在线观看| 欧美日产在线观看| 精品毛片乱码1区2区3区 | 日韩女优av电影在线观看| 日韩视频在线观看一区二区| 欧美激情综合网| 一区二区三区国产精华| 青青青伊人色综合久久| 国产成人综合网站| 一本久久a久久精品亚洲| 在线成人免费观看| 国产嫩草影院久久久久| 亚洲一区中文在线| 国产精品一区二区黑丝| 在线观看91视频| 国产亚洲精品aa午夜观看| 亚洲国产日韩一级| 国产一区二区免费看| 欧美日韩一级片网站| 国产午夜精品久久久久久久 | 国产一区二区按摩在线观看| a亚洲天堂av| 精品国产欧美一区二区| 亚洲精品一二三四区| 国产精品99久久不卡二区| 欧美精品自拍偷拍动漫精品| 国产精品免费aⅴ片在线观看| 欧美aaaaaa午夜精品| 91久久奴性调教| 国产精品成人免费| 国产一区二区美女| 日韩欧美国产1| 亚洲一级二级三级| 成人午夜精品在线| 精品国产免费一区二区三区四区| 亚洲午夜精品网| 91在线高清观看| 国产精品久久影院| 国产激情视频一区二区三区欧美 | 在线亚洲高清视频| 中文av一区二区| 国产综合成人久久大片91| 337p亚洲精品色噜噜狠狠| 一区二区三区四区视频精品免费| 成人精品视频网站| 中文在线一区二区| 成人免费看片app下载| 久久精子c满五个校花| 国产在线精品一区二区| 精品国产污污免费网站入口| 美日韩一区二区| 欧美一区国产二区| 日本不卡在线视频| 欧美一区二区三区在线观看视频| 午夜视频在线观看一区二区三区| 91国偷自产一区二区三区观看 | 久久亚洲一区二区三区明星换脸 | 日韩激情一二三区| 91麻豆精品国产| 蜜桃久久久久久| 欧美精品一区二区三区视频| 国产一区二区三区免费| 国产偷国产偷精品高清尤物| 成人激情免费网站| 亚洲欧美另类小说| 欧美无乱码久久久免费午夜一区| 亚洲福利视频导航| 欧美一卡二卡三卡| 国产91精品精华液一区二区三区| 国产精品天干天干在线综合| 91麻豆精东视频| 性做久久久久久久久| 精品国产污网站| 成人在线视频首页| 亚洲图片欧美一区| 精品福利一区二区三区免费视频| 国产91精品一区二区麻豆亚洲| 亚洲男人的天堂在线观看| 欧美日本精品一区二区三区| 激情综合网激情| 中文字幕中文乱码欧美一区二区| 欧美午夜视频网站| 国内精品久久久久影院一蜜桃| 亚洲欧美偷拍卡通变态| 日韩色视频在线观看| 成人av网址在线| 日韩黄色一级片| 日韩理论在线观看| 欧美成人在线直播| 日本电影亚洲天堂一区| 久久99热99| 亚洲激情五月婷婷| 国产亚洲成年网址在线观看| 欧美伊人久久大香线蕉综合69| 狠狠色狠狠色综合日日91app| 亚洲男帅同性gay1069| 久久美女高清视频| 欧美精品久久久久久久多人混战 | 欧美色中文字幕| 国产成人免费视频一区| 香蕉成人伊视频在线观看| 久久久久国产精品人| 欧美三级日韩三级| 97久久精品人人做人人爽| 日本午夜精品一区二区三区电影 | 国产色一区二区| 欧美精品一级二级三级| 成人a区在线观看| 激情国产一区二区| 免费av成人在线| 丝袜亚洲另类丝袜在线| 亚洲精品视频在线看| 国产精品毛片无遮挡高清|