• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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

相同都知道,多条件检索事实上就是依据用户选择的条件项,然后来拼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
大功告成~。





鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
充分利用ASP.NET的三种缓存提高站点性能发布时间:2022-07-10
下一篇:
Visual Studio 2010 RC 下安装ASP.NET MVC 2.0 RTM发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap