在c#中实现3层架构

Posted on 2006-05-07 16:28 我本善良 阅读(3022) 评论(12) 编辑 收藏
  原版英文文章地址:http://www.codeproject.com/csharp/three_tier_architecture.asp

介绍

这篇文章讨论如何在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的缩写。为了方便我把三个层编译到一个项目中。

 用户接口层

   下面是用户接口成的一段代码,我只选取了调用商业逻辑层的一部分代码。


商业逻辑层

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

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

 

 

数据访问层

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

Feedback

#1楼  回复 引用 查看   

2006-05-07 16:47 by Terrylee      
给楼主提个建议:把代码格式整理一下,最好高亮显示,这样太乱了~~~

#2楼  回复 引用 查看   

2006-05-07 17:31 by Justin Wang      
同意楼上,有点看不下去

#3楼  回复 引用   

2006-05-07 18:46 by fds2003[未注册用户]
同意一楼的话,把代码整理下,这么样看得很吃力呀!!
前段时间我也用3层架构做了一个设计,都是采用调用存储过程的!!上面的都用OleDb方式,性能不怎么样!!

#4楼  回复 引用   

2006-05-07 21:05 by sun lu
怎么出来一个商业逻辑层.....都做生意去了?

#5楼  回复 引用   

2006-05-07 21:38 by ddee[未注册用户]
的确代码有点乱

#6楼  回复 引用   

2006-05-07 21:40 by inet[未注册用户]
用过一个非常简单的三层结构代码自动生成工具,http://www.maticsoft.com

#7楼  回复 引用   

2006-05-12 10:41 by 最新qq表情[未注册用户]
还行,简单明了

#8楼  回复 引用   

2006-05-20 08:28 by jiansuper[未注册用户]
看的眼睛有点花,不过文章很好。我初学的

#9楼  回复 引用   

2006-05-23 20:13 by 会编程的狗[未注册用户]
晕,怎么DAL里还有与业务对象有关的内容?
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";

#10楼  回复 引用   

2007-05-26 17:41 by hd[未注册用户]
接分

#11楼  回复 引用   

2008-01-04 13:06 by 周进波[未注册用户]
想问问.数据访问层是用com+实现吗???商业逻辑层也要用com+实现吗???

#12楼  回复 引用 查看   

2010-04-12 17:21 by coldcat      
DA层用到BUSINESS对象定义,奇怪了,这样不好把...

posts - 2, comments - 15, trackbacks - 0, articles - 0

Copyright © 我本善良