当前位置:知识百问>生活百科>三层架构

三层架构

2024-06-16 23:48:44 编辑:join 浏览量:557

问题补充说明:protected void Button1_Click(object sender, EventArgs e) { s_studentTableAdapter adapter = new s_studentTableAdapter(); var data = adapter.GetDataByusername(username.Text.Trim()); if(data.Count <= 0) { } }运行时出先出现错误,错误提示是:错误 1 找不到类型或命名空间名称“var”(是否缺少 using 指令或程序集引用?) 哪位大侠能帮我看看!!!

三层架构

通常意义上的三层架构就是将整个业务来自应用划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的目的即为了“高内聚,低耦合”的思想。

1、表现层(UI):通俗讲就是展现给用户的界面,即用户在使用一个系统的360问答时候他的所见所得。

2、业务逻辑层(BLL):针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。

3、数据访问层(DAL):该层所做事务直接操作数据库,针对数据的增添、删除、修改、更新、查找等。

三层结构原理:

3困察群提间现名快个层次中,系统主要功能烟思副决写实推教心德游和业务逻辑都在业务逻辑层进行处理。

所谓三层体系结构,是在客户端与数据库之间加入了一个“中间层”,也叫组件层。这里所说的三层体系,不是指物理上的三层,不是简单地放置三台机器就是三层体系结构,也不仅仅有B/S应用才是三层体系结构,三层是指逻辑上官简件氧具的三层,即使这三个层放置到一台机器上。

三层体系的应用程序将业务规则、数据访问、合法性校验等工作放到了中间层进行处理。通常情况下,客户端不直接与数据库进行交互,而是通过COM/DCOM通讯与中间层建立连接,再经由中间层与数据库进行交互。

表示层

位于最外层(最上层),离用户最近。用于显示数据和接收用户输入的数据,为用户提供一种交互式操作的界面。

业务逻辑层

业务逻辑层(BusinessLogicLayer)无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、业务流程的实现等与业陆大务需求有关的系统设计,也即是说它是与系统所应对的领域(Domain)逻辑有关,很多时候,也将业务逻辑层称为领域层。例如MartinFowler在《PatternsofEnterpriseApplication营工鱼杂Architecture》一书中,将整个架构分为三个主要裂审统凯输丰史祖触训的层:表示层、领域层和数据源层。作为领域驱动设计的先驱EricEvans,对业务逻辑层作了更细致地划分,细分为应用层与领域层,通过分层进一步将领域逻辑飞逐氧握沉层现护机与领域逻辑的解决方案识区分离。

业务逻辑层在话体系架构中的位置很关键阳,它处于数据访问层与表示层中间,起到了数据交换中承上启下的作用。由于层是一种弱耦合结构,层与层之间的顺环精德准取依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有任何影响。如果在分层设计时,遵循了面向接口设计的思想,那么这种向下的依赖也应该赵沿质松古食换是一种弱依赖关系。因而在不改变接口定义的前提下,理想的分层式架构,应立游唱必期应其该是一个支持可抽取、可替换的“抽屉”式架构。正因为如此,业务逻辑层的设计对于一个支持可扩展的架构尤为关键,因为它扮演了两个不同的角色。对于数据访问层而言,它是调用者;对于表示层而言,它却是被调用者。依赖与被依赖的关系志都纠结在业务逻辑层上,如何实现依赖关系杀核坐它乐变希甲燃房女的解耦,则是除了实现业务逻辑之外留给设计师的任务。

数据两销丝八解见沉地按层

数据访问层:有时候也称为是持久层,其功能主要是负责数据库的访问,可以访问数据库系统、二进制文件、文本文档或是XML文档。

简单的说法就是实现对数据表的选控孩陈适犯给蛋底树按Select,Insert,Update,Delete的操作。如果要加入ORM的元素,那么就会包括对象和数据表之间的mapping,以及对象实体的持久化。

三层结构的程序不是说把项目分成DAL,BLL,WebUI三个模块就叫三层了,下面几个问题在你的项目里面:

1.UILayer里面只有少量(或者没有)的SQL语句或者存储过程调用,并且这些语句保证不会修改数据?

2.如果把UILayer拿掉,你的项目还能在Interface/API的层次上提供所有功能吗?

3.你的DAL可以移植到其他类似环境的项目吗?

4.三个模块,可以分别运行于不同的服务器吗?

如果不是所有答案都为YES,那么你的项目还不能算是严格意义上的三层程序.三层程序有一些需要约定遵守的规则:

1.最关键的,UI层只能作为一个外壳,不能包含任何BizLogic的处理过程

2.设计时应该从BLL出发,而不是UI出发.BLL层在API上应该实现所有BizLogic,以面向对象的方式

3.不管数据层是一个简单的SqlHelper也好,还是带有Mapping过的Classes也好,应该在一定的抽象程度上做到系统无关

4.不管使用COM+(EnterpriseService),还是Remoting,还是WebService之类的远程对象技术,不管部署的时候是不是真的分别部署到不同的服务器上,最起码在设计的时候要做这样的考虑,更远的,还得考虑多台服务器通过负载均衡作集群

所以考虑一个项目是不是应该应用三层/多层设计时,先得考虑下是不是真的需要?实际上大部分程序就开个WebApplication就足够了,完全没必要作的这么复杂.而多层结构,是用于解决真正复杂的项目需求的规则

另外,团IDC网上有许多产品团购,便宜有口碑

标签:架构,三层

版权声明:文章由 知识百问 整理收集,来源于互联网或者用户投稿,如有侵权,请联系我们,我们会立即处理。如转载请保留本文链接:https://www.zhshbaiwen.com/life/344039.html
热门文章