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<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用三层实现多条件检索

时间: 2024-10-09 20:10:54

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

ASP.NET典型三层架构企业级医药行业ERP系统实战

我这里有一套课程和大家分享,我的qq是2059055336,   课程说明: 国内首部完整讲述ERP系统架构.业务逻辑.开发的项目实战课程.考虑到本系统的庞大及复杂性.本课程原价购买学员每人赠送一个U盾设备,U盾可插在任意电脑上进行学习,使用方便,学习灵活!可永久学习! 项目由来: 此项目是讲师亲自参与构架及参与开发的大型ERP项目,此项目已被太阳石药业,九芝堂药业,拜欧药业等多家大中型企业使用,为其创造巨大经济价值.整个项目由10多个研发人员全程打造,项目总价值接近3000万,给企业创造的价值

ASP.NET的三层架构(DAL,BLL,UI)

BLL 是业务逻辑层 Business Logic Layer DAL 是数据访问层 Data Access Layer ASP.NET的三层架构(DAL,BLL,UI) 图形表示三层结构. 其中web即为USL层 web –> bll –> dal | | | | V | +–> model <-+ 一.三层体系架构 1.表示层(USL):主要表示WEB方式,也可以表示成WINFORM方式.如果逻辑层相当强大和完善,无论表现层如何定义和更改,逻辑层都能完善地提供服务. 2.业务逻

安装配置数据库mysql+springMVC 与数据库连接完成 检索,条件检索和插入

新建表:Test-----右键Create  Table-----在表中添加字段 一.项目与数据库连接 1.修改数据库登录用户名和密码,连接数据库 context.xml (片段) <Context> <Resourcename="jdbc/TerasolunaSampleDataSource" type="javax.sql.DataSource"driverClassName="com.mysql.jdbc.Driver"

ASP.NET典型三层架构企业级医药行业ERP系统实战(8大模块22个子系统,价值3000万)

课程讲师:Tiger     课程分类:.net         适合人群:高级       课时数量:192课时       更新程度:完毕 我这里有一套课程和大家分享,我的qq是2059055336,有兴趣的朋友可以和我聊天. 课程说明:国内首部完整讲述ERP系统架构.业务逻辑.开发的项目实战课程.考虑到本系统的庞大及复杂性.本课程原价购买学员每人赠送一个U盾设备,U盾可插在任意电脑上进行学习,使用方便,学习灵活!可永久学习! 项目由来:此项目是讲师亲自参与构架及参与开发的大型ERP项目,此

asp.net mvc 三层架构之dal层查询方法

分享分享分享!!! 首先,MVC和三层架构,是不一样的. 三层架构中,DAL(数据访问层).BLL(业务逻辑层).WEB层各司其职,意在职责分离. .net的三层结构中,并没有action这个概念. asp.net mvc 是微软新发布的一种网站开发架构.为了解决传统asp.net开发中不能分离Model,View和Controller而设计的. 普通的网站为了解决可移植,可维护,可扩展等问题,会把网站设计成三个独立的模块,Model负责数据库部分,View负责网页的界面,而Controller

在界面条件检索时设置默认时间

在项目模块中,模块大多有查询功能,那时间查询也就成了经常用到的事,如果数据量大,在切换界面的时候,会自动加载一次数据分页显示,可是却是对全表数据查询,在执行时,性能也就变得慢很多,有人会说,那一开始切换界面时,不加载数据,那界面就不太美观了,因为你这个界面模块,除了检索条件框外,下面空空的,我们至少要显示一些数据给别人,让一个界面看起来有规范而满满的东西. 那我们就可以给时间检索加一个默认时间,比如前后默认为一周七天,这样客户在第一次各模块界面切换时,读取的就是七天的数据,一来有数据,二来解决了

Asp.Net的三层架构与实现 (转)

一.三层架构的介绍: 三层架构,是为了便于我们开发项目后维护及变更的一种有效而实用的架构模式,在各种B/S项目中被广泛的采用着. 首先让我们来认识一下三层结构及每一层之前的作用和调用关系. 三层,即: 数据访问层(DAL):主要是对数据的增.删.改.查操作. 业务逻辑层(BLL):包含了项目中的业务逻辑,负责调用DAL中的方法实现业务的处理,并在表示层与数据访问层之间起到衔接的作用. 表示层(WebUI):用于显示数据和接受用户输入数据的一层,即为用户界面. 二.三层架构的实现: 1.将表抽象成

Asp.Net之三层架构

三层架构之理论: 通常意义上讲的三层架构就是将整个项目应用划分为:表现层(UI),业务逻辑层(BLL),数据访问层(DAL).与传统的二层架构的区别在于在用户界面(UI)和数据库服务器之间,添加中间层.而中间层又可划分为业务逻辑层(BLL),数据访问层(DAL)和数据对象模型层(Model).其中的数据对象模型层(Model)可以把表当做一个对象来处理,充分体现了面向对象的思想.三层架构因为"高内聚,低耦合"的特性,更利于 系统的设计和开发,同时为可能的变更提供了更小的单元,有利于系统

asp.net网站三层架构详解和反射知识

项目文件架构 实现步骤为:4-3-6-5-2-1ID项目描述用途 项目引用关系 实例所需文件 相关方法 1 Web 表现层 Web页和控件 引用BLL WebUI.aspx WebUI.aspx.cs GetContent() 2 BLL 业务逻辑层 业务逻辑组件 引用 IDAL,Model,使用DALFactory创建实例 Content.cs ContentInfo GetContentInfo(int id) 3 IDAL 数据访问层接口定义 每个DAL实现都要实现的一组接口 引用 Mod