C#三层架构 简单实例分析
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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层中,通常都会