三层架构+工厂模式(BLL、DAL、IDAL、MODEL、DBUtility、DALFactory解释)

本文主要是介绍三层架构+工厂模式(BLL、DAL、IDAL、MODEL、DBUtility、DALFactory解释),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三层架构,我们一般说的三层架构通常指的是:1、表现层(UI):就是展现给用户的界面,无论是网站前台还是应用程序界面;2、业务逻辑层(BLL):针对具体问题的逻辑操作;3、数据访问层(DAL):对数据进行操作。其他的层级基本都是在这三层之上的补充。

UI(User Interface)表示层:

就是我们看到的网站前台、应用程序界面。

BLL(Business Logic Layer)业务逻辑层:

主要是针对数据业务逻辑的处理。它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计。它处于数据访问层与表示层中间,起到了数据交换中承上启下的作用。对于表示层而言它是被调用者,对于数据访问层而言它则是调用者。如果说数据层是积木,那逻辑层就是对这些积木的搭建层。

DAL(Data Access Layer)数据访问层:

主要是对数据的操作而不是数据库,具体为上层业务逻辑层提供数据服务。简单地说就是写数据连接和执行的SQL语句来实现对实体也就是数据表的增、删、改、查的操作。进一步的话可以加入ORM的元素,那么就会包括对象和数据之间的表mapping,以及对象尸体的持久化。

DAL中常用的技术有ADO.NET + SQL语句、O/R Mapping框架 NHiberate、访问不同数据源时LINQ TO (SQL、Oracle、XML)。

IDAL(Interface Data Access Layer)DAL的接口层:

是DAL的接口层它体现了“抽象”的精神,或者说是“面向接口编程”的最佳体现。在工厂设计模式中需要支持多数据源时面向接口编程的思想就有所体现。然后“IUserDAL iUserDal = new UserDAL();”。逻辑上我们可以这么理解,那就是以为存在这样的关系:BLL->IDAL->DAL,认为IDAL起到了BLL和DAL之间的桥梁作用,BLL是通过IDAL作为接收器来接收不同的DAL的对象。实际上你如此编码:“IUserDAL iUserDal = ClassFacotry.CreateUserDAL();”,那么在执行“iUserDal.SelectUsers()”时,其实还是执行的UserDAL实例,而不是IUserDAL实例,所以IDAL在三层中的位置是与DAL平级的关系。但是面向接口的思想就在此体现了。

MODEL这是实体/数据模型层:

一般来讲Model层里面的一个类对应数据库里面的一张表,类里面的每一个属性对应表里面的每一个字段,每个属性都有自己的 GET 和 SET 方法, 项目中的数据存取都要依靠GET和SET方法来实现。它其实就是面向对象编程中最基本的东西:类。确切的说它不属于纵向的哪一层,而是所有层都要用到的业务实体层。这样,Model在三层架构中的位置,和int,string等变量的地位就一样了,没有其它的目的,仅用于数据的存储而已,只不过它存储的是复杂的数据。当你取数据时,如果使用DataSet,就没有体现"面向对象"。相反,如果把DataSet里的行,变成Model层里的类对象。把DataSet变成List<>这样的集合,更面向对象,也更符合多层架构的设计思想。(是对象的集合,不是数据行的集合)。或者使用泛型集合来代替DATASET。 IList<Model.实体类名>……

通常MODEL里面的类,应该是和数据库里面表相对应的。这样,你可以直接取表里面的某个字段。通过这种方法将MODEL的实体和数据库表映射类,封装数据库文件。

DBUtility:

是连接数库的方法。只是约定俗成的一个分类法,不是必须的。一般里面都放SqlHelper这样的类在里面,由DAL中的数据访问类来调用。也就是说DBUtility包含的是访问数据库的通用代码。

DALFactory抽象工厂类:

作为创建DAL对象的工厂,并通过DataAccess类放到这个抽象工厂里面去。对添加对IDAL项目的引用。在DataAccess类中,我们创建对象通过xml配置文件来将“条件外置”和“反射技术”实现。通过配置文件的程序集名,决定加载具体的那个DAL的程序集,动态组合类名来动态创建DAL对象,并返回IDAL接口对象(面向接口编程,IDAL可接收SQLServerDAL和OracleDAL等不同的实现),为了性能和使用方便,DataAccess类全部采用静态方法实现。

总结:

大体思想是3层,从Model,DAL,BLL,然后他在各层上又采用了工厂模式,把逻辑与实现分离,比如以前BLL直接调用DAL就好了,但现在BLL却调用了IDAL,IDAL只是一个接口层,里面封装了要完成的一些业务逻辑,而具体的实现则交给DAL去实现,然后借助于工厂模式DALFactory和反射技术动态加载程序集来完成IDAL层中类的实例化。这样不管我们底层用的是什么数据库都可以完成BLL对DAL的调用。首先你不应该将那些SQL语句放在BLL层中,而应该是由DAL层来完成和数据库的交互,DAL层又调用DBUtility的通用访问数据库代码来实现对数据库的连接访问。他们之间的关系为DAL引用MODEL, BLL引用 DAL 和 MODEL,UI引用BLL和MODEL。

转载

这篇关于三层架构+工厂模式(BLL、DAL、IDAL、MODEL、DBUtility、DALFactory解释)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/515780

相关文章

Nginx location匹配模式与规则详解

《Nginxlocation匹配模式与规则详解》:本文主要介绍Nginxlocation匹配模式与规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、环境二、匹配模式1. 精准模式2. 前缀模式(不继续匹配正则)3. 前缀模式(继续匹配正则)4. 正则模式(大

Pydantic中model_validator的实现

《Pydantic中model_validator的实现》本文主要介绍了Pydantic中model_validator的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录引言基础知识创建 Pydantic 模型使用 model_validator 装饰器高级用法mo

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查