背景

  首先,我介紹一些3層架構的 " /> 毛片a区,亚欧毛片基地国产毛片基地,亚洲二区在线

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

在C#中實現3層架構

  這篇文章討論如何在c#中實現3層架構,使用MS Access數據庫存儲數據。在此,我在3層架構中實現一個小型的可復用的組件保存客戶數據。并提供添加,更新,查找客戶數據的功能。

  背景

  首先,我介紹一些3層架構的理論知識。簡單說明:什么是3層架構?3層架構的優點是什么?

  什么是3層架構?

  3層架構是一種“客戶端-服務器”架構,在此架構中用戶接口,商業邏輯,數據保存以及數據訪問被設計為獨立的模塊。主要有3個層面,第一層(表現層,GUI層),第二層(商業對象,商業邏輯層),第三層(數據訪問層)。這些層可以單獨開發,單獨測試。

  為什么要把程序代碼分為3層。把用戶接口層,商業邏輯層,數據訪問層分離有許多的優點。

  在快速開發中重用商業邏輯組件,我們已經在系統中實現添加,更新,刪除,查找客戶數據的組件。這個組件已經開發并且測試通過,我們可以在其他要保存客戶數據的項目中使用這個組件。

  系統比較容易遷移,商業邏輯層與數據訪問層是分離的,修改數據訪問層不會影響到商業邏輯層。系統如果從用SQL Server存儲數據遷移到用Oracle存儲數據,并不需要修改商業邏輯層組件和GUI組件

  系統容易修改,假如在商業層有一個小小的修改,我們不需要在用戶的機器上重裝整個系統。我們只需要更新商業邏輯組件就可以了。

  應用程序開發人員可以并行,獨立的開發單獨的層。

  代碼

  這個組件有3層,第一個層或者稱為GUI層用form實現,叫做FrmGUI。第二層或者稱為商業邏輯層,叫做BOCustomer,是Bussniess Object Customer的縮寫。最后是第三層或者稱為數據層,叫做DACustomer,是Data Access Customer的縮寫。為了方便,我把三個層編譯到一個項目中。

  用戶接口層

  下面是用戶接口成的一段代碼,我只選取了調用商業邏輯層的一部分代碼。

//This function get the details from the user via GUI 
//tier and calls the Add method of business logic layer.
private void cmdAdd_Click(object sender, System.EventArgs e)
{
try
{
cus
= new BOCustomer();
cus.cusID
=txtID.Text.ToString();
cus.LName
= txtLName.Text.ToString();
cus.FName
= txtFName.Text.ToString();
cus.Tel
= txtTel.Text.ToString();
cus.Address
= txtAddress.Text.ToString();
cus.Add();
}
catch(Exception err)
{
MessageBox.Show(err.Message.ToString());
}
}
//This function gets the ID from the user and finds the
//customer details and return the details in the form of
//a dataset via busniss object layer. Then it loops through
//the content of the dataset and fills the controls.
private void cmdFind_Click(object sender, System.EventArgs e)
{
try
{
String cusID
= txtID.Text.ToString();
BOCustomer thisCus
= new BOCustomer();
DataSet ds
= thisCus.Find(cusID);
DataRow row;
row
= ds.Tables[0].Rows[0];
//via looping
foreach(DataRow rows in ds.Tables[0].Rows )
{
txtFName.Text
= rows["CUS_F_NAME"].ToString();
txtLName.Text
= rows["CUS_L_NAME"].ToString();
txtAddress.Text
= rows["CUS_ADDRESS"].ToString();
txtTel.Text
= rows["CUS_TEL"].ToString();
}
}
catch (Exception err)
{
MessageBox.Show(err.Message.ToString());
}
}
//this function used to update the customer details.
private void cmdUpdate_Click(object sender, System.EventArgs e)
{
try
{
cus
= new BOCustomer();
cus.cusID
=txtID.Text.ToString();
cus.LName
= txtLName.Text.ToString();
cus.FName
= txtFName.Text.ToString();
cus.Tel
= txtTel.Text.ToString();
cus.Address
= txtAddress.Text.ToString();
cus.Update();
}
catch(Exception err)
{
MessageBox.Show(err.Message.ToString());
}
}

NET技術在C#中實現3層架構,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 美女扒开内衣看个够网站 | 欧美a色| 精品国产91| 97国内免费久久久久久久久久 | 国产精品 主播精选 网红 | 九九国产视频 | 亚洲一区免费视频 | 色久影院 | 国内精品中文字幕 | 亚洲第一成人在线 | 国产综合视频在线观看 | 91精品国产高清久久久久久91 | 四虎影视色费永久在线观看 | 四虎国产精品永久在线看 | 九一国产精品视频 | 国产男女免费视频 | 五月激情久久 | 欧美性巨大欧美 | 欧美三级视频在线观看 | 综合免费一区二区三区 | 日本免费www | 国产大臿蕉香蕉大视频 | 久久中文网| 国产精品久久久久久麻豆一区 | 日韩色爱| 黄在线| 成人免费视频网 | 欧美日韩国产码高清综合人成 | 2021国产精品自产拍在线 | 激情五月综合综合久久69 | 欧美成人网在线综合视频 | 开心丁香婷婷深爱五月 | 一本久道久久综合多人 | 色呦呦视频在线观看 | 亚洲丝袜一区二区 | 一区二区三区高清在线观看 | 激情网站网址 | 涩综合 | 亚洲欧洲无码一区二区三区 | 国产精品第九页 | 91久久国产|