.NET三层架构各项目之间的引用关系及如何添加引用?
1.1三层之间的引用
整个.NET框架的项目创建完成之后,在开发之前,还需要建立各个项目之间的引用关系,以便在编写C#业务逻辑代码时调用相关项目的类库。
1.1.1 引用关系规则
.NET三层架构中的UI、BLL、DAL、Model之间的引用是有顺序的,不能随便的引用和调用。它们之间的引用规则如下:
- Model层被UI、BLL、DAL层引用和调用。
- UI层只能引用和调用BLL层和Model层。
- BLL层只能引用和调用DAL层和Model层。
- DAL层只能与Model交互,并且操作SQL Server数据库。
1.2. 添加引用关系
我们在Visual Studio开发工具中,创建了4个项目,这4个项目的名称空间都是不一样的,并且都存在不同的文件夹中。默认不能相互调用。它们之间如果要相互调用,这必须添加项目引用。
在没有添加项目引用的情况下,各层之间是独立的,隔离的。
1.2.1. UI引用BLL和Model
UI层是用户界面层,或称为表示层,是供用户访问的界面,因此,在经典.NET三层架构中创建的各层最终都是为UI层服务的。经过各层的逻辑处理之后,最终有用的数据就会流转到UI层并供用户查看和使用。
按照经典.NET三层架构之间的引用规则,UI层只能引用和调用BLL层和Model层。
1.2.2. BLL引用DAL和Model
BLL层是业务逻辑层,主要用于复杂的业务逻辑处理,然后将处理后的数据传递给UI层,UI层再呈现给用户。
而BLL层的数据是从DAL层过来的,DAL层是与SQL Server数据库接触的,因为我们最终的数据是永久存储在SQL Server数据库中的,所以通过DAL层就能够拿到原始数据,再在Model层的帮助下,以对象的形式将取出的原始数据传递给BLL层。
所以,BLL层需要引用DAL层和Model层。
1.2.3. DAL引用Model
在经典.NET三层架构中,DAL层是处理原始数据的一层,主要作用是从SQL Server数据库中获取原始数据。通过使用Model实体层,可以让数据以对象的形式获取。
最后,由于Model是实体层,只是一些由类封装的属性组成的,给三层之间传递数据使用的,所以不需要引用其它项目。
.NET三层架构各项目之间的引用关系及如何添加引用?的更多相关文章
- 使用VS创建三层架构的项目
使用VS创建三层架构的项目 1.打开VS软件: 2.创建新项目: 3.创建新项目打开后选择SAP的选项点击创建{注:上面还有一个和这个相似的项目创建:看清楚在选择: 4.创建后改下名字,框架如果不是3 ...
- 手动创建Maven项目并建立两个项目之间的依赖关系
用命令行快速建立maven项目 -> mvn:archetype:generate -> 直接回车或者自己输入你想生成的 -> groupId ->artifactId -&g ...
- 三层架构与MVC之间的区别
文章转发自:http://www.admin10000.com/document/535.html 我们平时总是将三层架构与MVC混为一谈,殊不知它俩并不是一个概念.下面我来为大家揭晓我所知道的一些真 ...
- C# 好用的三层架构,项目直接上手用
一.项目结构 注意:1.Common类中的引用添加:右键--添加引用--.NET--选择对应的引用 2.各层之间引用互相添加(这个就不必多说了,三层最基础部分) 3.在添加 Oracle 引用时候 ...
- [转]三层架构与MVC之间的区别
我们平时总是将三层架构与MVC混为一谈,殊不知它俩并不是一个概念.下面我来为大家揭晓我所知道的一些真相. 首先,它俩根本不是一个概念. 三层架构是一个分层式的软件体系架构设计,它可适用于任何一个项目. ...
- .NET Core添加项目之间的依赖关系
- Web项目的三层架构和MVC架构异同
http://www.cnblogs.com/zhhh/archive/2011/06/10/2077519.html 又看到有人在问三层架构和MVC的关系,感觉这种问题有点教条化了.因为它们都在逻辑 ...
- MVC项目实践,在三层架构下实现SportsStore-02,DbSession层、BLL层
SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...
- MVC项目实践,在三层架构下实现SportsStore-01,EF Code First建模、DAL层等
SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...
随机推荐
- DVWA学习记录 PartⅦ
SQL Injection 1. 题目 SQL Injection,即SQL注入,是指攻击者通过注入恶意的SQL命令,破坏SQL查询语句的结构,从而达到执行恶意SQL语句的目的. 2. Low a. ...
- redis(十一):Redis 列表(List) (python)
# -*- coding: utf-8 -*- import redis r =redis.Redis(host="123.156.74.190",port=6379,passwo ...
- 数据可视化之PowerQuery篇(十四)产品关联度分析
https://zhuanlan.zhihu.com/p/64510355 逛超市的时候,面对货架上琳琅满目的商品,你会觉得这些商品的摆放,或者不同品类的货架分布是随机排列的吗,当然不是. 应该都听说 ...
- 如何手写一个ArrayList
写完HashMap,觉得手痒痒,所以隔了一天再来实现一下简单的ArrayList,ArrayList相比而言就非常的简单,主要的核心点有以下几个方面: 1.ArrayList的底层是由数组构成的 2. ...
- P1100 高低位切换
这个题很简单 直接用左移位(<<)和右移位(>>)就可以过了 #include<iostream> #include<cstdio> using nam ...
- CENTOS下搭建git代码仓库 ssh协议
centos服务器下搭建git仓库,使用ssh协议管理仓库代码权限 git官网(http://git-scm.com/) 使用ssh协议: 一.安装git,使用yum install git 或 ...
- 文件传输协议---TFTP
简介 TFTP协议全称为简单文件传输协议,是以UDP为基础的应用层协议,主要用于不同设备之间的文件传输.具有协议简单,易于实现的特点,常用于嵌入式设备开发中. 传输模式 数据的存储有不同的格式,磁盘中 ...
- 深入探究JVM之内存结构及字符串常量池
前言 Java作为一种平台无关性的语言,其主要依靠于Java虚拟机--JVM,我们写好的代码会被编译成class文件,再由JVM进行加载.解析.执行,而JVM有统一的规范,所以我们不需要像C++那样需 ...
- java文件导出过程 CS、BS差别
最近在做一个需求,类似和navicat工具差不多的,通过java代码吧数据库表的数据导出来.jdbc获取数据库连接,查询表数据,分批次用流写入文件txt.csv.json.xls.xlsx,搞定之后, ...
- Mybatis(四)多表操作
数据库如下: 一.创建数据库所对应的bean类 public class User { private Integer uId; private String username; private St ...