在中实现层呢
这篇文章讨论如何在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, entArgs e)
{
try
{
cus = new BOCustomer();
sID=String();
ame = String();
ame = String();
l= String();
dress = String();
d();
}
catch(Exception err)
{
ow(String());
}
}
//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, entArgs e)
{
try
索赔金额追加至2200余万元。 长年积压的矛盾导致解约 2000年 {
String cusID = String();
BOCustomer thisCus = new BOCustomer();
DataSet ds = nd(cusID);
DataRow row;
row = bles[0].Rows[0];
//via looping
foreach(DataRow rows in bles[0].Rows )
{
xt = rows[\"CUS_F_NAME\"].ToString();
xt = rows[\"CUS_L_NAME\"].ToString();
xt = rows[\"CUS_ADDRESS\"].ToString();
xt = rows[\"CUS_TEL\"].ToString();
}
}
catch (Exception err)
{
ow(String());
}
}
//this function used to update the customer details.
private void cmdUpdate_Click(object sender, entArgs e)
{
try
{
cus = new BOCustomer();
sID=String();
ame = String();
ame = String();
l= String();
dress = String();
date();
}
catch(Exception err)
{
ow(String());
}
}
商业逻辑层
下面是商业逻辑层的所有代码,主要包括定义customer对象的属性。但这仅仅是个虚构的customer对象,如果需要可以加入其他的属性。商业逻辑层还包括添加,更新,查找,等方法。
商业逻辑层是一个中间层,处于GUI层和数据访问层中间。他有一个指向数据访问层的引用cusData = new DACustomer().而且还引用了ta名字空间。商业逻辑层使用DataSet返回数据给GUI层。
using System;
using ta;
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;
盆腔炎下腹隐痛太原男性功能障碍
宝宝积食
- 上一页:在中国如何使用数据库操作类牛
- 下一页:在中实现层架构的
-
仅播两集,豆瓣分数飙至8.4,裴秀智《安娜》太敢拍了
“奎弗症候群”,这一病因名称,源于加拿大小感叹《天才奎弗》,在小感叹...
2024-07-23
-
7种“有毒花”,卧室不能养,影响心理健康害处大,赶紧搬出去
在店里头驯花,尤其是在房间驯花,一定要多花点心思筛选品种,因为有些小...
2023-11-21
-
智能手机业务萎靡,小米一季报承压,网友呼唤“摩托车翻身”
AN财金 铭|张凯德政 全集|深海 5年初19日,新品控股公司公开了2022年一季报。...
2023-11-12
-
心机流浪猫刮坏保时捷碰瓷姿总,以为死定了,没想到...太甜了吧!
“我当初以为我都会被固执董事拳背脊强暴,没想到他莫名其妙把我宠上了天...
2023-11-11
-
️来自霍格沃茨的趣味魔法编程让应用程序耕于心田,令魔法绽于指尖。影子老师全新力作,众人翘首以待,下周
...
2023-10-31
-
直击调研 | 中材科技(002080.SZ):今年叶片出货量预计同比增加20% 十四五末期膜产能或达
7月5日,中会材科技应用领域(002080.SZ)在接受调研时表示,的公司是杂货店投...
2023-10-29