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

   三层将项目分为界面层,业务逻辑层和数据访问层,下面为大家介绍下asp.net如何用三层实现多条件检索,感兴趣的朋友可以参考下

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

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

  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 books = searchBll.Searc(ss);//这里调用Bll进行操作

  Bll就先不说,主要是Dal层的sql拼接

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

  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

时间: 2024-09-13 20:01:59

asp.net用三层实现多条件检索示例的相关文章

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

众所周知,三层将项目分为界面层,业务逻辑层和数据访问层(以最基本的三层为例) 同样都知道,多条件检索其实就是根据用户选择的条件项,然后来拼sql语句 那么,既然要根据用户选择的条件项来拼sql语句,就肯定要在界面层接收用户的选择,这时候问题来了: 我是要在界面层拼sql语句吗,这么做完全没问题,功能也完全可以实现,可是这么一来,你是破坏了三层的原则了吗 那么还架三层做什么? 那我在数据访问层拼sql语句好了,然后问题又来了: 在数据访问层拼的话这么知道用户选择了哪几个条件项呢,根据分层的原则,是

asp.net的三层结构在编程的过程中怎么体现?

问题描述 asp.net的三层结构在编程的过程中怎么体现? 我理解的是:在"设计"处布局按钮什么的,在按钮的事件里写方法.主要以前见老师给的网上书店里还有什么book类,comment类了,我不是很理解,因为有文章说asp.net天然是三层,我理解的对吗?求大牛告知. 解决方案 关于ASP.NET的三层结构关于ASP.NET的三层结构ASP.NET中的三层结构 解决方案二: 其实三层不止是三层 我们都称作是三层架构而已 还有Model实体层 和Utility工具层 用于添加实体 你的B

java条件检索xml

问题描述 <?xmlversion="1.0"encoding="utf-8"?><config><searchkey>id</searchkey><itemid="AQDAjax">org.web.ajax.AQDAjax</item><itemid="AADAjax">org.web.ajax.AADAjax</item><

ASP.NET MVC3视图占位符RenderSection使用示例

hared/MasterPage.cshtml:  代码如下 复制代码 <!DOCTYPE html> <html> <head>     <title>@ViewBag.Title</title>     @this.RenderSection("Head_Js", false) </head> <body>     @this.RenderSection("Body_Content&quo

利用ASP技术开发基于WWW的数据库检索程序

程序|数据|数据库  ASP是微软公司推出的用以取代CGI的新技术,是目前公认的建立Windows NT动态站点最好的工具.它与ADO(Active Data Object,一种新的数据访问模型)的充分结合,提供了强大的数据库访问功能,使之成为进行网上数据库管理的重要手段.     一.ASP简介   ASP内含于Internet Information Server(简称IIS3.0)中,扩展名以.asp表示.ASP文件可以用常规的文本编辑器编辑,也可以利用专门的辅助开发工具InterDev进

什么是ASP.NET中三层结构

asp.net|三层结构 一.三层体系架构 1.表示层(USL):主要表示WEB方式,也可以表示成WINFORM方式.如果逻辑层相当强大和完善,无论表现层如何定义和更改,逻辑层都能完善地提供服务. 2.业务逻辑层(BLL):主要是针对具体的问题的操作,也可以理解成对数据层的操作,对数据业务逻辑处理.如果说数据层是积木,那逻辑层就是对这些积木的搭建. 3.数据访问层(DAL):主要是对原始数据(数据库或者文本文件等存放数据的形式)的操作层,而不是指原始数据,也就是说,是对数据的操作,而不是数据库,

ASp.net 剖析三层架构

转自:http://blog.sina.com.cn/s/blog_5ea9354f0100dea0.html 三层实现的留言和查看留言 本文不是从理论的角度来探讨三层架构,而是用一个示例来介绍如何建设一个三层架构的项目,并说明项目中各个文件所处的层次与作用.写本文的目的,不是为了说明自己的这个方法有多对,别人的肯定不对,而是希望给那些初学三层架构却不知从何入手的朋友提供一点帮助.因为网上的文章,大多是注重理论的介绍,而忽略了具体的实践应用,或者有示例但讲得不透彻.导致看了之后,理论上又学习了一

asp.net实现三层架构的例子_实用技巧

看了2天的三层架构,其实自己以前也看过这个,可以由于没有使用过,所以对于三层架构也只是知道罢了,昨天看了一下他一些内部的具体架构,三层分别是BLL.WEB.DAL,在web接受用户请求,bll处理业务,dal处理数据库事务,下面是一个简单的例子!这是一个添加新员工的页面: 后台代码如下: usingSystem.Collections; usingSystem.Web; usingSystem.Web.Security; usingSystem.Web.UI; usingSystem.Web.U

比较不错的asp单表单字段多条件查询_应用技巧

用途:文章表内文章关键字查询 查询格式: 百度 google  百度好还是google好 百度+google (也可不输入条件全部查询) <!--#include file="conn.asp"--> <% Function SearshSQL(Tname,Lname,Str) 'Tname-表名 Lname-列名 Str-查询的字符 If Trim(Str)="" then         MySql="Select * From &q