数据访问层(DAL):该层所作事务直接操做数据库,针对数据的增添、删除、修改、查找等。因此D层的类对应的就是表。数据库
业务逻辑层(BLL):针对具体问题的操做,也能够说是对数据层的操做,对数据业务逻辑处理。架构
表示层(UI):通俗讲就是展示给用户的界面,即用户在使用一个系统的时候他的所见所得。app
实体层(Entity):就是数据库全部表的。每一个表都是一个类,表的字段就是属性。实体层为传递各类数据的容器,至关于一个载体。(下面不做过多介绍)函数
3个层次中,系统主要功能和业务逻辑都在业务逻辑层进行处理。spa
所谓三层体系结构,是在客户端与数据库之间加入了一个“中间层”,也叫组件层。三层体系的应用程序将业务规则、数据访问、合法性校验等工做放到了中间层进行处理(以下图)。一般状况下,客户端不直接与数据库进行交互,而是经过COM/DCOM通信与中间层创建链接,再经由中间层与数据库进行交互。设计
1:数据访问层:主要是对原始数据(数据库或者文本文件等存放数据的形式)的操做层,而不是指原始数据,也就是说,是对数据的操做,而不是数据库,具体为业务逻辑层或表示层提供数据服务.对象
2:业务逻辑层:主要是针对具体的问题的操做,也能够理解成对数据层的操做,对数据业务逻辑处理,若是说数据层是积木,那逻辑层就是对这些积木的搭建。接口
3:表示层:主要表示WEB方式,也能够表示成WINFORM方式,WEB方式也能够表现成:aspx,若是逻辑层至关强大和完善,不管表现层如何定义和更改,逻辑层都能完善地提供服务。事务
1:数据访问层:主要看你的数据层里面有没有包含逻辑处理,实际上他的各个函数主要完成各个对数据文件的操做。而没必要管其余操做。数据访问层有时候也称为是持久层,其功能主要是负责数据库的访问,能够访问数据库系统、二进制文件、文本文档或是XML文档。简单的说法就是实现对数据表的Select,Insert,Update,Delete的操做。若是要加入ORM的元素,那么就会包括对象和数据表之间的mapping,以及对象实体的持久化。开发
2:业务逻辑层:主要负责对数据层的操做。也就是说把一些数据层的操做进行组合。业务逻辑层无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计,也便是说它是与系统所应对的领域(Domain)逻辑有关,不少时候,也将业务逻辑层称为领域层。业务逻辑层在体系架构中的位置很关键,它处于数据访问层与表示层中间,起到了数据交换中承上启下的做用。因为层是一种弱耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有任何影响。若是在分层设计时,遵循了面向接口设计的思想,那么这种向下的依赖也应该是一种弱依赖关系。于是在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的“抽屉”式架构。正由于如此,业务逻辑层的设计对于一个支持可扩展的架构尤其关键,由于它扮演了两个不一样的角色。对于数据访问层而言,它是调用者;对于表示层而言,它倒是被调用者。依赖与被依赖的关系都纠结在业务逻辑层上,如何实现依赖关系的解耦,则是除了实现业务逻辑以外留给设计师的任务。
3:表示层:主要对用户的请求接受,以及数据的返回,为客户端提供应用程序的访问。位于最外层(最上层),离用户最近。用于显示数据和接收用户输入的数据,为用户提供一种交互式操做的界面。
咱们知道饭店将整个业务分解为三部分来完成,每一部分各负其责,服务员只管接待顾客、向厨师传递顾客的需求;厨师只管烹炒不一样口味、不一样特点的美食;后勤工做人员只管提供美食原料;他们三者分工合做共同为顾客提供满意的服务。在饭店为顾客提供服务期间,服务员、厨师、后勤工做人员,三者中任何一者的人员发生变化时都不会影响其余俩者的正常工做,只对变化者进行从新调整便可正常营业。
咱们用三层结构开发的软件系统于此相似,表示层只提供软件系统与用户交互的接口;业务逻辑层是表示层和数据访问层之间的桥梁,负责数据处理和传递;数据访问层只负责数据的存取工做。
思想上移与三层架构知识相结合: