首页 > 网站 > 建站经验 > 正文

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

2019-11-02 14:20:27
字体:
来源:转载
供稿:网友

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

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

  同样都知道,多条件检索其实就是根据用户选择的条件项,然后来拼sql语句

  那么,既然要根据用户选择的条件项来拼sql语句,就肯定要在界面层接收用户的选择,这时候问题来了:

  我是要在界面层拼sql语句吗,这么做完全没问题,功能也完全可以实现,可是这么一来,你是破坏了三层的原则了吗

  那么还架三层做什么?

  那我在数据访问层拼sql语句好了,然后问题又来

美女搞笑动态图片[www.62-6.com/1/meinvgaoxiao/]
了:

  在数据访问层拼的话这么知道用户选择了哪几个条件项呢,根据分层的原则,是不能把诸如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"];

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表