国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網(wǎng)站 > 建站經(jīng)驗 > 正文

asp.net用三層實現(xiàn)多條-件檢索示例

2019-11-02 14:20:27
字體:
供稿:網(wǎng)友

   三層將項目分為界面層,業(yè)務邏輯層和數(shù)據(jù)訪問層,下面為大家介紹下asp.net如何用三層實現(xiàn)多條件檢索,感興趣的朋友可以參考下

  眾所周知,三層將項目分為界面層,業(yè)務邏輯層和數(shù)據(jù)訪問層(以最基本的三層為例)

  同樣都知道,多條件檢索其實就是根據(jù)用戶選擇的條件項,然后來拼sql語句

  那么,既然要根據(jù)用戶選擇的條件項來拼sql語句,就肯定要在界面層接收用戶的選擇,這時候問題來了:

  我是要在界面層拼sql語句嗎,這么做完全沒問題,功能也完全可以實現(xiàn),可是這么一來,你是破壞了三層的原則了嗎

  那么還架三層做什么?

  那我在數(shù)據(jù)訪問層拼sql語句好了,然后問題又來

美女搞笑動態(tài)圖片[www.62-6.com/1/meinvgaoxiao/]
了:

  在數(shù)據(jù)訪問層拼的話這么知道用戶選擇了哪幾個條件項呢,根據(jù)分層的原則,是不能把諸如textBox1.Text這樣的數(shù)據(jù)傳給數(shù)據(jù)訪問層的

  其實解決的方案就是第二種方式,只是中間通過一個條件模型類來傳遞用戶的選擇

  條件模型類如下:

  public class SearchModel

  {

  public string Name { get; set; }//記錄數(shù)據(jù)庫字段名

  public string Value { get; set; }//記錄對應的值

  public Action Action { get; set; }//記錄相應的操作

  }

  選擇很難看出這個類的作用到底是什么,接著走你~

  之后要準備一個枚舉:

  public enum Action

  {

  Lessthan,

  Greatthan,

  Like,

  Equart

  }

  對應數(shù)據(jù)中中的幾個操作,如<,>,like,=等,可以根據(jù)自己的需要添加

  當然你也可以用數(shù)字,不過魔鬼數(shù)字最好不要使用,所以還是定義一個枚舉吧~動動手指頭就ok了

  假設現(xiàn)在要對一個圖書表進行多條件檢索

  在界面層中的代碼:

  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"];

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 兰州市| 安阳县| 霍林郭勒市| 遂溪县| 东明县| 武平县| 平顶山市| 尼玛县| 启东市| 吉水县| 瑞丽市| 江阴市| 洪江市| 宁波市| 大厂| 饶平县| 土默特左旗| 南雄市| 星子县| 江山市| 元江| 平顶山市| 铜鼓县| 达日县| 巫山县| 保山市| 阜城县| 威远县| 辽宁省| 丹棱县| 汶川县| 庄浪县| 固安县| 清流县| 正阳县| 公安县| 水富县| 陇南市| 全南县| 隆回县| 多伦县|