C#三层架构 简单实例分析

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

基于3层架构的课程管理系统

本模块工作任务

任务3-1:三层架构划分

任务3-2:数据访问层的实现

任务3-3:业务逻辑层的实现 任务3-4:表示层的实现

本模块学习目标

1、掌握三层架构的划分原理

2、掌握各层的设计思路,和层之间的调用关系

3、利用三层架构实现对课程管理模块的重构

4、巩固OOP 的基本概念和 OOP 的编程思路

---------------------------------------------------------------------------------------------------------------------------------

任务3-1:三层架构划分

效果与描述

图3.1 包含多个项目的3层架构解决方案

本任务要求学生能够将原来的只有1个项目的课程管理模块,重构为标准的具有5个项目的3层架构的模块,并进行恰当的初始化,仍能实现课程记录的添加、浏览功能。在此过程中理解3层架构的划分原理,各层的任务,层之间的调用关系。

本任务的业务流程: 将原项目改为UI 层

新建BLL/ DAL/COMMON/MODL 项

目并初始化

初始化后仍能实现课程记录的浏览和添

业务逻辑层

数据访问层

界面层

图3.2 单层转化为3层架构的业务流程

相关知识与技能

3-1-1 三层架构的划分原理

三层架构的划分如下图:

图3.3 三层架构原理图

1、各层的任务

数据访问层:使用中的数据操作类,为数据库中的每个表,设计1个数据访问类。类中实现:记录的插入、删除、单条记录的查询、记录集的查询、单条记录的有无判断等基本的数据操作方法。对于一般的管理信息软件,此层的设计是类似的,包含的方法也基本相同。此层的任务是:封装每个数据表的基本记录操作,为实现业务逻辑提供数据库访问基础。

业务逻辑层:为用户的每个功能模块,设计1个业务逻辑类,此时,需要利用相关的数据访问层类中,记录操作方法的特定集合,来实现每个逻辑功能。

界面层:根据用户的具体需求,为每个功能模块,部署输入控件、操作控件和输出控件,并调用业务逻辑层中类的方法实现功能。

2、层之间的调用关系

数据访问层的类,直接访问数据库,实现基本记录操作。

业务逻辑层的类,调用相关的数据访问类,实现用户所需功能。

界面层:部署控件后,调用业务逻辑层的类,实现功能。

将应用程序的功能分层后,对于固定的DBMS,数据访问层基本可以不变,一旦用户的需求改变,首先修改业务逻辑层,界面层稍做改动即可。这种做法使程序的可复用性、可修改性,都得到了很好的改善,大大提高了软件工程的效率。

3-1-2 ORM(对象关系映射)

在图3.1中看到,除了界面层、业务逻辑层和数据访问层之外,还有2个项目。其中,Common项目中一般放的是公用文件,如数据操作类DBHelper等,被数据访问层的类调用,其必要性在上个模块已述。Modal项目中存放的是实体类。

所谓的对象关系映射Object Relational Mapping,简称ORM,是为了解决面向对象的类,与关系数据库的表之间,存在的不匹配的现象,通过使用描述对象和关系之间映射的元数据,在程序中的类对象,与关系数据库的表之间建立持久的关系,用于在程序中描述数据库表。本质上就是将数据从一种形式转换到另外一种形式。

ORM是一个广义的概念,适应于关系数据库与应用程序之间的各类数据转换,目前有许多自动转换工具可用,如codesmith 等。在本教材中,利用手工书写代码的形式,实现ORM。

如对于学生选课管理系统数据库中的课程表course,其设计视图如下:

图3.4 Course表设计视图

可以这样设计类来描述它:

public class Course

{

private string courseId;

public string CourseId

{

get { return courseId; }

set { courseId = value; }

}

private string courseName;

public string CourseName

{

get { return courseName; }

set { courseName = value; }

}

private int courseCredit;

public int CourseCredit

{

get { return courseCredit; }

set { courseCredit = value; }

}

public Course() { }

public Course(string courseId,string courseName,int courseCredit)

{

this.courseId = courseId;

this.courseName = courseName;

this.courseCredit = courseCredit;

}

}

将表中的每个字段抽取为类的字段(注意类型匹配),并封装成属性,设计构造函数,来将表抽取为类。这种类就称为实体类。这个抽取过程称为对象关系映射ORM。

在Modal项目中,为数据库的每个表,都设计一个相应的实体类,这样,就相当于对每个表实体,在.NET程序中,都可以通过类对象来应用。在上面介绍的3层中,通常都会

相关文档
最新文档