asp.net用三層實現(xiàn)多條件檢索示例
來源:易賢網(wǎng) 閱讀:1076 次 日期:2014-07-17 18:58:31
溫馨提示:易賢網(wǎng)小編為您整理了“asp.net用三層實現(xiàn)多條件檢索示例”,方便廣大網(wǎng)友查閱!

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

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

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

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

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

那么還架三層做什么?

那我在數(shù)據(jù)訪問層拼sql語句好了,然后問題又來了:

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

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

條件模型類如下:

public class SearchModel

{

public string Name { get; set; }//記錄數(shù)據(jù)庫字段名

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

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

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

之后要準備一個枚舉:

public enum Action

{

Lessthan,

Greatthan,

Like,

Equart

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

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

假設現(xiàn)在要對一個圖書表進行多條件檢索

在界面層中的代碼:

List<SearchModel> ss = new List<SearchModel>();

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<T_Books> books = searchBll.Searc(ss);//這里調(diào)用Bll進行操作Bll就先不說,主要是Dal層的sql拼接

public List<T_Books> Search(List<SearchModel> 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<T_Books> list = new List<T_Books>();

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;//返回符合條件的圖書集合,完成

更多信息請查看IT技術專欄

更多信息請查看網(wǎng)絡編程
易賢網(wǎng)手機網(wǎng)站地址:asp.net用三層實現(xiàn)多條件檢索示例

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權所有:易賢網(wǎng)