凯锐

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

        前段時間,研究了一下微軟的PetShop3.x,(最近PetShop4.0也出來, 不過沒有時間再去看了。因爲機器上沒有裝VS.NET2005)並試著寫了一個多層結構的小方案,現將實現步驟整理出來,希望初學能儘快掌握多層結構
        
            1﹑新建資料庫,
NtierData,作爲測試使用,我只建了一個表Users,表結構設計如下,讀者朋友可根據下表自行設計。

ColumnName Condensed Type Nullable Description
ID int not null 主鍵﹐自增
UserName varchar(50) null 用戶名
PassWord varchar(50) null 用戶密碼

          
            2﹑由於我們實現的是一個WEB方案,第二步我們就需要設置好IIS,並將其指向你所希望的目錄。由於這一步比較簡單,讀者朋友自行設計好。

        3﹑接下就要進行設計了。打開VS.NET2003,選擇新建空白解決方案,然後先後加入新建專案,並分別起名DAL,BLL,Model,最後加入一個Web方案NTierWeb.

        4﹑至此,我們的多層結構程式已經初具雛形了,有表示層NtierWeb,有資料訪問層DAL,有業務層BLL等。

        5﹑打開Web.Config文件,加入以下這段話

          <appSettings>

                <add key="ConnectionString" value="server=localhost;database=NTierData;uid=sa;password= " />

          </appSettings>

        密碼改成你的資料庫密碼。

        6﹑Model方案,新增專案類UserInfo,這個類,按照PetShop來看,應該就是所謂的“建模”,在這個類的前面加上[Serializable],關於自動建模可以在網上找到很多工具來代勞的,由於我這裏只有一個表,所以就手工敲了一下。

        7﹑接下來,我們就可以設計資料訪問層DAL了,新增專案類SQLHelper.cs,該類可以拷貝PetShop3.0SQLServerDAL下的SQLHelper.cs,修改刪除幾個不需要的東東就可以使用了。呵呵接著我們需要新加一個類DBConn,該類只需要一個方法。

           public static  SqlConnection GetConn()

         {

                SqlConnection _sqlConn =  new SqlConnection(ConfigurationSettings.AppSettings["ConnectionString"]);

                return _sqlConn;

           }

            當然我們還需要加入一個IUser類(這個專案是仿PetShop的嘛),先只做一個插入的方法;
           public  int Insert(UserInfo userinfo)

           {

                string strSql = "Insert Into Users(UserName,PassWord)Values(@UserName,@PassWord)";

                SqlParameter[] param =new SqlParameter[]{

                                                                           new SqlParameter("@UserName",SqlDbType.VarChar,50),

                                                                           new SqlParameter("@PassWord",SqlDbType.VarChar ,50)

                                                                     };

                param[0].Value = userinfo.UserName;

                param[1].Value = userinfo.PassWord;

                try

                {

                     SQLHelper.ExecuteNonQuery(DBConn.GetConn(),CommandType.Text,strSql,param);

                     return 0;

                }

                catch

                {

                     return 1;

                }

       }

 

        8﹑接下來,我們就可以進入BLL層的設計了,新加專案類Users,並加入方法
           public int Insert(UserInfo userinfo)

           {

                return new IUsers().Insert(userinfo);

           }

        9﹑至此,我們就可以關注介面表示層了,新加一個名爲Default的頁面。從工具欄上拖三個Label,兩上Textbox,和一個Button過來。排列好,將TextBox分別命名tbxUserNametbxPassWord,將Button命名爲btnAdd,,寫btnAdd的單擊事件。

           private void btnAdd_Click(object sender, System.EventArgs e)

           {

                UserInfo userinfo = new UserInfo();

                userinfo.UserName = tbxUserName.Text.Trim().Replace("'","''");

                userinfo.PassWord = tbxPassWord.Text.Trim().Replace("'","''");

                if(new Users().Insert(userinfo)==0)

                {

                     this.Label1 .Text = "Success!";

                }

                else

                {

                     this.Label1.Text = "Fail!";

                }

           }

        10﹑NtierWeb設爲起始專案,並將Default.aspx設爲起始頁,然後按F5就可以看到你剛做的簡單的多層架構的專案的。呵呵,有點如釋重負的感覺,原來多層結構也就這麽簡單。

 

        由於是第一次寫這樣的文章,用詞表達方面可能達不到大家的滿意度,也終於體會到寫文章其實也是一件蠻辛苦蠻累的事情,對原創作者又多了一層敬意:),如果需要這篇文章的源碼的朋友,可以與我聯系jinliangliu@163.comQQ52433739(注明C# Developer)或在這里下載
 

posted on 2006-02-27 08:55  凯锐  阅读(1248)  评论(1编辑  收藏  举报