首页 | 互联网 | IT动态 | Cisco | Windows | Linux | Java | .Net | Oracle | 华为 | 存储世界 | 服务器 | 网络设备 | IDC | 安全 | 求职招聘
IT培训 | 数字网校 | 技术专题 | 电子书下载 | 教学视频 | 网页设计 | 平面设计 | 解决方案 | 直播室 | 虚拟考场 | 搜索 | 博客 | 沙龙 | 论坛
中国IT实验室Dotnet频道
中国IT教育
首页 ASP.NET  C#  XML/WebService ADO.NET VC.NET VB.NET .NET 资讯动态 专题 RSS订阅 讨论 下载
您现在的位置: 中国IT实验室 >> Dotnet >> C# >> 文章正文

教你在c#中实现3层架构

文章来源中国it实验室收集整理 作者佚名 更新时间2008-4-29 保存本文保存本文 推荐给好友推荐给好友 收藏本页收藏本页

    这篇文章讨论如何在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());

    }

    }

 

[1] [2] [3] 下一页  

【责编:Ken】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题
 ·展现C#世界 C#程序设计专题
 ·Java入门 Tomcat的配置技巧精华专题
 ·Oracle RMAN物理备份技术详解
 ·JAVA开发利器——JBuilder知多少
 今日更新
 社区讨论
 博客论点
 频道精选
 Dotnet频道相关导航