.net三层结构的简单理解

原创 2007年10月15日 08:05:00

我用代码来表示吧

(1)表示层的按钮事件

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());

}

}

商业逻辑层

下面是商业逻辑层的所有代码,主要包括定义customer对象的属性。但这仅仅是个虚构的customer对象,如果需要可以加入其他的属性。商业逻辑层还包括添加,更新,查找,等方法。

商业逻辑层是一个中间层,处于GUI层和数据访问层中间。他有一个指向数据访问层的引用cusData = new DACustomer().而且还引用了System.Data名字空间。商业逻辑层使用DataSet返回数据给GUI层。

using System;

using System.Data;

namespace _3tierarchitecture

{

/// <SUMMARY>

/// Summary description for BOCustomer.

/// </SUMMARY> 

public class BOCustomer

{

//Customer properties

private String fName;

private String lName;

private String cusId;

private String address;

private String tel;

private DACustomer cusData;

public BOCustomer()

{

//An instance of the Data access layer!

cusData = new DACustomer();

}  

/// <SUMMARY>

/// Property FirstName (String)

/// </SUMMARY>

public String FName

{

get

{

return this.fName;

}

set

{

try

{

this.fName = value;

if (this.fName == "")

{

throw new Exception(

"Please provide first name ...");

}

}

catch(Exception e)

{

throw new Exception(e.Message.ToString());

}

}

}

/// <SUMMARY>

/// Property LastName (String)

/// </SUMMARY>

public String LName

{

get

{

return this.lName;

}

set

{

//could be more checkings here eg revmove ' chars

//change to proper case

//blah blah

this.lName = value;

if (this.LName == "")

{

throw new Exception("Please provide name ...");

}

}

}    

/// <SUMMARY>

/// Property Customer ID (String)

/// </SUMMARY>

public String cusID

{

get

{

return this.cusId;

}

set

{

this.cusId = value;

if (this.cusID == "")

{

throw new Exception("Please provide ID ...");

}

}

}

/// <SUMMARY>

/// Property Address (String)

/// </SUMMARY>

public String Address

{

get

{

return this.address;

}

set

{

this.address = value;


if (this.Address == "")

{

throw new Exception("Please provide address ...");

}

}

}

/// <SUMMARY>

/// Property Telephone (String)

/// </SUMMARY>

public String Tel

{

get

{

return this.tel;

}

set

{

this.tel = value;

if (this.Tel == "")

{

throw new Exception("Please provide Tel ...");

}

}

}

/// <SUMMARY>

/// Function Add new customer. Calls

/// the function in Data layer.

/// </SUMMARY>

public void Add()

{

cusData.Add(this);

}

/// <SUMMARY>

/// Function Update customer details.

/// Calls the function in Data layer.

/// </SUMMARY>

public void Update()

{

cusData.Update(this);

}

/// <SUMMARY>

/// Function Find customer. Calls the

/// function in Data layer.

/// It returns the details of the customer using

/// customer ID via a Dataset to GUI tier.

/// </SUMMARY>

public DataSet Find(String str)

{

if (str == "")

throw new Exception("Please provide ID to search");

DataSet data = null;

data = cusData.Find(str);

return data;

}

}

}


数据访问层

数据层包括处理MS Access数据库的细节。所有这些细节都是透明的,不会影响到商业逻辑层。数据访问层有个指向商业逻辑层的引用BOCustomer cus。为了应用方便并且支持其他数据库。
using System;

using System.Data.OleDb;

using System.Data;

namespace _3tierarchitecture

{

/// <SUMMARY>

/// Summary description for DACustomer.

/// </SUMMARY>

public class DACustomer

{

private OleDbConnection cnn;

//change connection string as per the

//folder you unzip the files

private const string CnnStr =

"Provider=Microsoft.Jet.OLEDB.4.0;Data " +

"Source= D://Rahman_Backup//Programming//" +

"Csharp//3tierarchitecture//customer.mdb;";

//local variables

private String strTable="";

private String strFields="";

private String strValues="";

private String insertStr="";

//this needs to be changed based on customer

//table fields' Name of the database!

private const String thisTable = "tblCustomer";

private const String cus_ID = "CUS_ID";

private const String cus_LName = "CUS_L_NAME";

private const String cus_FName = "CUS_F_NAME";

private const String cus_Tel = "CUS_TEL";

private const String cus_Address = "CUS_ADDRESS";

public DACustomer()

{

}

public DACustomer(BOCustomer cus)

{

// A reference of the business object class

}

//standard dataset function that adds a new customer

public void Add(BOCustomer cus)

{

String str = BuildAddString(cus);

OpenCnn();

//Open command option - cnn parameter is imporant

OleDbCommand cmd = new OleDbCommand(str,cnn);

//execute connection

cmd.ExecuteNonQuery();

// close connection

CloseCnn();

}

//standard dataset function that updates

//details of a customer based on ID

public void Update(BOCustomer cus)

{

OpenCnn();

String selectStr = "UPDATE " + thisTable +

" set " + cus_LName + " = '" + cus.LName + "'" +

", " + cus_FName + " = '" + cus.FName + "'" +

", " + cus_Address + " = '" + cus.Address + "'" +

", " + cus_Tel + " = '" + cus.Tel + "'" +

" where cus_ID = '" + cus.cusID + "'";

OleDbCommand cmd = new OleDbCommand(selectStr,cnn);

cmd.ExecuteNonQuery();   

CloseCnn();

}

//standard dataset function that finds and

//return the detail of a customer in a dataset

public DataSet Find(String argStr)

{

DataSet ds=null;

try

{

OpenCnn();     

String selectStr = "select * from " + thisTable +

" where cus_ID = '" + argStr + "'";

OleDbDataAdapter da =

new OleDbDataAdapter(selectStr,cnn);

ds = new DataSet();

da.Fill(ds,thisTable);

CloseCnn();             

}

catch(Exception e)

{

String Str = e.Message;

}

return ds;

}

private void OpenCnn()

{

// initialise connection

String cnnStr = CnnStr;

cnn = new OleDbConnection(cnnStr);

// open connection

cnn.Open();

}

private void CloseCnn()

{

// 5- step five

cnn.Close();

}      

// just a supporting function that builds

// and return the insert string for dataset.

private String BuildAddString(BOCustomer cus)

{

// these are the constants as

// set in the top of this module.

strTable="Insert into " + thisTable;

strFields=" (" + cus_ID +

"," + cus_LName +

"," + cus_FName +

"," + cus_Address +

"," + cus_Tel + ")";          

//these are the attributes of the

//customer business object.

strValues= " Values ( '" + cus.cusID +

"' , '" + cus.LName +

"' , '" + cus.FName +

"' , '" + cus.Address +

"' , '" + cus.Tel + "' )";

insertStr = strTable + strFields + strValues;         

return insertStr;         

}

}

}

 

三层架构学习总结

三层的学习已经完成了,用了两天的时间来用C#和VB.net实现用户登录的功能,虽然看似很简单,看视频的时候觉得也没什么。照着视频敲完C#的用户登录,基本没有报错就成功了。可是用VB.NET时可就费了大...
  • u013045214
  • u013045214
  • 2015年04月26日 10:09
  • 1412

简单的三层架构及思想,总结(适合简单框架搭建)

从毕业到现在,从事软件行业不过两三年,但大大小小项目也做了几个,对于大项目,只能在自己的模块中比较了解,而对于整体的大框架,都是专家或架构师级别设计搭建的,但有好多小项目,基本都是个人完成的,所以在这...
  • TKWDmylove
  • TKWDmylove
  • 2014年01月04日 17:13
  • 1195

由简单三层到工厂模式

以ASP.NET为例,简单三层就是 DAL, BLL,Model 三层构成, DAL层处理数据,负责与数据打交道,比如SQL语句的书写等,DAL层处理完数据后的结果,交由BLL层,BLL层这时对数据进...
  • xuejunling
  • xuejunling
  • 2015年03月06日 12:48
  • 3373

简单的.NET三层框架的实现(学生作业管理系统)

三层架构,也有人叫做三层结构,是一种软件架构。 三层架构主要包括了表现层(UI)、业务逻辑层(BLL)和数据访问层(DAL)。这样的方式将软件开发进行分层,每层之间的分工是相对的比较明确的,而且很...
  • hurrycxd
  • hurrycxd
  • 2015年07月14日 22:29
  • 3375

简单三层登录

简单的聊一下写这篇博客的背景,在跟着三层视频敲三层的时候,用的是自己的数据库,所以导致在敲完后出现不少问题。敲三层的视频还是有漏洞的,他只能在显示登录成功,却不能显示登录失败,只要你输入的用户名和密码...
  • dsj15831653282
  • dsj15831653282
  • 2015年12月29日 19:16
  • 794

.net中的三层架构简介

三层架构(3-tier application) 通常意义上的三层架构就是将整个业务应用划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的目的即为了“高内聚,低耦合”的思想...
  • Vikerfeng
  • Vikerfeng
  • 2014年03月16日 13:25
  • 3060

MVC和三层架构

一、MVC M:(Model)  模型  :  应用程序的核心功能,管理这个模块中用的数据和值; V(View )视图:   视图提供模型的展示,管理模型如何显示给用户,它是应用程序的外观; C...
  • lyx1980916167
  • lyx1980916167
  • 2017年04月01日 16:04
  • 1942

三层架构(我的理解及详细分析)

三层架构已经学了一段时间,一直想做一个比较完整、比较完美的总结。但是左思右想,不知道如何下笔。都说万事开头难嘛,今天整理了一下凌乱的思路,哎,还是没整理好,想到哪就说到哪吧。   初学者很不理解: 1...
  • hanxuemin12345
  • hanxuemin12345
  • 2013年01月26日 17:13
  • 105992

三层结构的简单描述及优点,bs三层,web三层,j2ee三层

三层结构的简单描述及优点,bs三层,web三层,j2ee三层 三层结构的简单描述及优点   三层体系结构,即用户层、应用层和数据库服务器。用户层主要指用户界面,它要求尽可能的简单,使最终用...
  • pianistOfSoftware
  • pianistOfSoftware
  • 2016年07月14日 12:52
  • 2188

ASP.NET实现三层架构网站创建流程

1.新建项目—>Visual C#—>Web—>ASP.NET空Web应用程序  或者  新建网站—>ASP.NET空网站 2.在解决方案处右击—>新建项目—>Windows—>类库,分别创建三层架...
  • u011028345
  • u011028345
  • 2017年05月02日 14:41
  • 2704
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:.net三层结构的简单理解
举报原因:
原因补充:

(最多只允许输入30个字)