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

发表于:2014-7-16 10:24

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:Jchubby    来源:51Testing软件测试网采编

  众所周知,三层将项目分为界面层,业务逻辑层和数据访问层(以最基本的三层为例)
  同样都知道,多条件检索其实就是根据用户选择的条件项,然后来拼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了
  假设现在要对一个图书表进行多条件检索
21/212>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号