前段時間,研究了一下微軟的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.0的SQLServerDAL下的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分別命名tbxUserName和tbxPassWord,將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.com或QQ:52433739(注明C# Developer)或在這里下載