asp.net用三层实现多条件检索示例

所属分类: 网络编程 / ASP.NET 阅读数: 1782
收藏 0 赞 0 分享

众所周知,三层将项目分为界面层,业务逻辑层和数据访问层(以最基本的三层为例)

同样都知道,多条件检索其实就是根据用户选择的条件项,然后来拼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了

假设现在要对一个图书表进行多条件检索

在界面层中的代码:

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);//这里调用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语句传入,开始查询数据库 
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页面传值的具体实现,感兴趣的朋友可以参考下哈,本人水平有限,还请各位朋友多多指教
收藏 0 赞 0 分享

ASP.NET中操作SQL数据库(连接字符串的配置及获取)

要想在ASP.NET中操作SQL数据库首先需要在WebConfig中配置数据库连接字符串,之后在.cs文件中获取连接字符串,具体的配置及获取方法如下,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

三层+存储过程实现分页示例代码

本文为大家介绍下三层+存储过程分页的具体实现,前后台及存储过程代码如下,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

DataGridView - DataGridViewCheckBoxCell的使用介绍

Datagridview是.net中最复杂的控件,Datagridview中,用户可以对行、列、单元格进行编程,下面与大家分享下DataGridViewCheckBoxCell的使用,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

asp.net中javascript的引用(直接引入和间接引入)

Asp.net 中引入Javascript的方法有很多,个人认为可以分为直接引入,和间接引入,下面是两种具体的引用方法,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

Gridview用法大总结(全程图解珍藏版)

Gridview用法大总结啦!精彩效果截图加详细源代码注释,需要的朋友赶紧过来看看吧
收藏 0 赞 0 分享

HTTP错误500.19解决方法(定义了重复的节点)

HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效
收藏 0 赞 0 分享

Asp.Net 无刷新文件上传并显示进度条的实现方法及思路

这篇文章详细介绍了无刷新文件上传并显示进度条的思路和代码,有需要的朋友可以参考一下
收藏 0 赞 0 分享

Asp.net获取客户端IP常见代码存在的伪造IP问题探讨

如果某个网站是通过下面的代码获取IP,那么我们只要在Header里随意设置HTTP_VIA和X_FORWARDED_FOR,就可以达到伪造IP的目的
收藏 0 赞 0 分享

VS2010 水晶报表的使用方法

这篇文章简单介绍下VS2010 水晶报表的使用方法,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多