午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    asp.net用三層實(shí)現(xiàn)多條件檢索示例
    來(lái)源:易賢網(wǎng) 閱讀:1149 次 日期:2014-07-17 18:58:31
    溫馨提示:易賢網(wǎng)小編為您整理了“asp.net用三層實(shí)現(xiàn)多條件檢索示例”,方便廣大網(wǎng)友查閱!

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

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

    同樣都知道,多條件檢索其實(shí)就是根據(jù)用戶(hù)選擇的條件項(xiàng),然后來(lái)拼sql語(yǔ)句

    那么,既然要根據(jù)用戶(hù)選擇的條件項(xiàng)來(lái)拼sql語(yǔ)句,就肯定要在界面層接收用戶(hù)的選擇,這時(shí)候問(wèn)題來(lái)了:

    我是要在界面層拼sql語(yǔ)句嗎,這么做完全沒(méi)問(wèn)題,功能也完全可以實(shí)現(xiàn),可是這么一來(lái),你是破壞了三層的原則了嗎

    那么還架三層做什么?

    那我在數(shù)據(jù)訪(fǎng)問(wèn)層拼sql語(yǔ)句好了,然后問(wèn)題又來(lái)了:

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

    其實(shí)解決的方案就是第二種方式,只是中間通過(guò)一個(gè)條件模型類(lèi)來(lái)傳遞用戶(hù)的選擇

    條件模型類(lèi)如下:

    public class SearchModel

    {

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

    public string Value { get; set; }//記錄對(duì)應(yīng)的值

    public Action Action { get; set; }//記錄相應(yīng)的操作

    }選擇很難看出這個(gè)類(lèi)的作用到底是什么,接著走你~

    之后要準(zhǔn)備一個(gè)枚舉:

    public enum Action

    {

    Lessthan,

    Greatthan,

    Like,

    Equart

    }對(duì)應(yīng)數(shù)據(jù)中中的幾個(gè)操作,如<,>,like,=等,可以根據(jù)自己的需要添加

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

    假設(shè)現(xiàn)在要對(duì)一個(gè)圖書(shū)表進(jìn)行多條件檢索

    在界面層中的代碼:

    List<SearchModel> ss = new List<SearchModel>();

    if (!string.IsNullOrEmpty(Request.Form["txtName"]))//如果用戶(hù)在名字框中輸入了文字

    {

    SearchModel model = new SearchModel();

    model.Name = "BookName";//要操作的字段為書(shū)名

    model.Value = Request.Form["txtName"];//對(duì)應(yīng)的值為用戶(hù)輸入的文字

    model.Action = Action.Like;//操作為like

    ss.Add(model);

    }//以下類(lèi)似

    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);//這里調(diào)用Bll進(jìn)行操作Bll就先不說(shuō),主要是Dal層的sql拼接

    public List<T_Books> Search(List<SearchModel> ss)//接收傳進(jìn)來(lái)的條件模型類(lèi)集合,并對(duì)其進(jìn)行遍歷

    {

    string sql = "select * from T_Books where IsDelete=0 and ";//開(kāi)始拼接sql語(yǔ)句

    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語(yǔ)句傳入,開(kāi)始查詢(xún)數(shù)據(jù)庫(kù)

    foreach (DataRow row in table.Rows)

    {

    T_Books book = GetModelByDataRow.GetBooks(row);

    list.Add(book);

    }

    return list;//返回符合條件的圖書(shū)集合,完成

    更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

    更多信息請(qǐng)查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機(jī)網(wǎng)站地址:asp.net用三層實(shí)現(xiàn)多條件檢索示例
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

    2025國(guó)考·省考課程試聽(tīng)報(bào)名

    • 報(bào)班類(lèi)型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專(zhuān)用圖標(biāo)
    聯(lián)系電話(huà):0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
    咨詢(xún)QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)