眾所周知,三層將項目分為界面層,業(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)在要對一個圖書表進行多條件檢索
在界面層中的代碼:
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);//這里調(diào)用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語句傳入,開始查詢數(shù)據(jù)庫
foreach (DataRow row in table.Rows)
{
T_Books book = GetModelByDataRow.GetBooks(row);
list.Add(book);
}
return list;//返回符合條件的圖書集合,完成
假設用戶輸入下圖的條件:
![](http://img.jbzj.com/file_images/article/201407/201407081145033.gif?201468114515)
最后貼上測試拼接的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實現(xiàn)依賴注入1-Model層
- asp.net實現(xiàn)三層架構的例子
- ASP.NET MVC5 網(wǎng)站開發(fā)框架模型、數(shù)據(jù)存儲、業(yè)務邏輯(三)
- ASP.NET創(chuàng)建三層架構圖解詳細教程
- 在ASP.NET 2.0中操作數(shù)據(jù)之一:創(chuàng)建一個數(shù)據(jù)訪問層
- 在ASP.NET 2.0中操作數(shù)據(jù)之二:創(chuàng)建一個業(yè)務邏輯層