三层架构—简析

    三层学习完了,第一次验收的时候,自己理解的也不是非常到位,后来又又一次敲了一遍登陆样例,查阅了一些资料

进行第二次验收才感觉清晰了很多。之前画时序图时我就想过时序图基本上也是非常好的体现了三层,当时也和别人讨

论过这个问题。

直到学完三层后,更加证明了这一点。

    以下我将从理论和实践两个角度总结一下三层。


理论篇


    为什么使用三层架构?


    说白了,分层的目的是想将复杂问题简单化,也就是面向对象技术所崇尚的“高内聚,低耦合”。当业务复杂到

一定程度。数据存储在独立的存储介质时适合用三层架构。


    什么是三层架构?


    通常意义上的三层架构(3-tier architecture)就是将整个业务应用划分为:表现层(UI)、业务逻辑层

(BLL)、数据訪问层(DAL)。

    图解



    表现层(UI):主要是指人机交互界面。用于接收用户输入的数据和显示处理后用户须要的数据。

    业务逻辑层(BLL):连接UI和DAL的桥梁。

    数据訪问层(DAL):实现数据库的增、删、改、查。

    实体类(Model):不属于三层的范畴,个人理解的建立实体类的目的是将加载的数据库中的数据放入当中,

UI、BLL、DAL。哪个须要就从实体类中获取。封装数据,避免了传參数造成的复杂,从而避免了各个层与数据库的直

接接触,造成数据交叉。各个层仅仅须要和实体层Model打交道就可以。

    点睛

    各个层各司其职,仅仅负责自己专属的功能。提高了内聚性,降低了彼此之间的耦合。Model是数据传输的业务数

据模型,不是数据库中的数据。Model是避免出现数据交而建立的。


    怎样搭建?


    优缺点?


    长处

        1、开发者能够仅仅关注整个结构中的当中某一层。

        2、能够减少层与层之间的依赖;

        3、有利于标准化,能够非常easy的用新的实现来替换原有层次的实现。

        4、在后期维护的时候,极大地减少了维护成本和维护时间

    缺点

        1、减少了系统的性能。这是不言而喻的。假设不採用分层式结构。非常多业务能够直接造訪数据库,以此获

取对应的数据。现在却必须通过中间层来完毕。

        2、有时会导致级联的改动。这样的改动尤其体如今自上而下的方向。

假设在表示层中须要添加一个功能。为

保证其设计符合分层式结构,可能须要在对应的业务逻辑层和数据訪问层中都添加对应的代码。

        3、添加了开发成本。


实战篇


    以下是一个登录窗口的DEMO


    UI层的代码


<span style="font-family:KaiTi_GB2312;font-size:18px;">namespace LoginUI
{public partial class Form1 : Form{public Form1(){InitializeComponent();}private void btnLogin_Click(object sender, EventArgs e){string userName = txtUserName.Text.Trim();   string password = txtPassword.Text;Login.BLL.LoginManager mgr = new Login.BLL.LoginManager();   //重载BLL层Login.Model.UserInfo user = mgr.UserLogin(userName, password);MessageBox.Show("登录用户:" + user.UserName);}}
}
</span>

    UI层,人机交互。须要引用BLL和Model层,从代码中能够看出UI层不包括不论什么逻辑推断的代码和跟数据库有关的

代码。


    BLL层的代码


<span style="font-family:KaiTi_GB2312;font-size:18px;">namespace Login.BLL
{public class LoginManager{public Login.Model.UserInfo UserLogin(string userName, string password)      //获得Model中封装的数据库中的数据(UI层中的){Login.DAL.UserDAO uDao = new Login.DAL.UserDAO();        //实例化UserDAO类Login.Model.UserInfo user = uDao.SelectUser(userName, password);           if (user != null)                                          // 加载成功{Login.DAL.ScoreDAO sDao = new Login.DAL.ScoreDAO();             //知道数据库连接成操作命令sDao.UpdateScore(userName, 10);return user;}else{throw new Exception("登录失败。");}
</span>

    从代码中能够看出BLL层也不和数据库打交道,没有SQL语句。

须要引用DAL和Model层。


    DAL层代码


<span style="font-family:KaiTi_GB231<span style="font-family: Arial, Helvetica, sans-serif;">2;font-size:18px;">namespace Login.DAL</span>
{public class UserDAO{public Login.Model.UserInfo SelectUser(string userName, string password)    //获取Model中的表中的数据,返回的是数据模型{using (SqlConnection conn = new SqlConnection(DbUtil.ConnString))      //建立数据库连接{SqlCommand cmd = conn.CreateCommand();  //表示要对 SQL Server 数据库运行的一个 Transact-SQL 语句或存储过程。

实例化一个接口,用以运行SQL指令 cmd.CommandText = @"SELECT ID, UserName, Password,Email FROM USERS WHERE UserName=@UserName AND Password=@Password"; cmd.CommandType = CommandType.Text; cmd.Parameters.Add(new SqlParameter("@UserName",userName)); //添加上面数据库连接中设的两个參数 cmd.Parameters.Add(new SqlParameter("@Password",password)); conn.Open(); //打开数据库 SqlDataReader reader = cmd.ExecuteReader(); Login.Model.UserInfo user = null; //默认值是Null while (reader.Read()) //读取数据库中的数据 { if (user == null) { user = new Login.Model.UserInfo(); //当Model是Null的话才载入数据 } user.ID = reader.GetInt32(0); user.UserName = reader.GetString(1); user.Password = reader.GetString(2); if (!reader.IsDBNull(3)) //假设Email不是Null的话,才干读取 { user.Email = reader.GetString(3); } } return user; } } } } </span>


    从代码中能够看出是直接和数据库打交道的,没有跟窗口控件有关的内容。须要引入Model层。


个人小结


    分层的目标是为了“高内聚。低耦合”。分层可将复杂的简单化。当需求须要改变时,你仅仅须要该对应部分而不

用大范围的改动。分层还提高了可维护性和可扩展性,但并非全部的都要分层,业务逻辑简单,没有真正的数据存

储层这时就不须要分层,假设分层反而会添加复杂度。所以我们寻常在使用时要注意灵活应用。



转载于:https://www.cnblogs.com/blfbuaa/p/7241251.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/429027.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php配置文件加载顺序,php extension 加载顺序问题

有的php扩展&#xff0c;加载是有先后顺序的&#xff0c;如果搞错了&#xff0c;会导致扩展无法加载。1&#xff0c;pdo_sqlsrv是sqlserver扩展&#xff0c;如果在pdo扩展之前加载就会报以下错误PHP Warning: PHP Startup: Unable to load dynamic library pdo_sqlsrv.so (trie…

机房收费系统之结账

其实&#xff0c;我认为机房收费系统中结账的部分是耗我精力最多的。首先我就不明确结账是干嘛的&#xff0c;所以一上来就晕乎乎。后来看了一篇博客说结账方便老板管理的才明确了为什么是“操作员”。这里面要理清的一点&#xff0c;结账的内容是未结账的。 暂时汇总的信息&am…

linux php oauth安装,php – 无法在Linux上安装OAuth

我正在尝试在Linux上安装OAuth,但它无法正常工作.我正在运行此命令&#xff1a;yum install php-devel然后pecl install oauth然后我得到这个输出&#xff1a;downloading oauth-1.2.2.tgz ...Starting to download oauth-1.2.2.tgz (45,348 bytes).............done: 45,348 b…

[NOIP2010提高组]关押罪犯

题目&#xff1a;洛谷P1525、Vijos P1776、codevs1069。 题目大意&#xff1a;有一些罪犯&#xff0c;两个罪犯之间可能会发生冲突&#xff0c;冲突有个影响力&#xff0c;而如果两个罪犯在不同监狱里&#xff0c;就可以避免冲突。现在有两个监狱&#xff0c;要你安排一种关押罪…

java一元二次方程面向对象,求解一元二次方程(面向对象设计的),跪求

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼头文件#if! defined(EQUATION_H)#define EQUATION_H#include #include using namespace std;class FindRoot{private:float a,b,c,d;double x1,x2;public:FindRoot(float x,float y,float z);void Find();void Display();};#endif实…

Java线上应用故障排查之一:高CPU占用

一个应用占用CPU很高&#xff0c;除了确实是计算密集型应用之外&#xff0c;通常原因都是出现了死循环。 以我们最近出现的一个实际故障为例&#xff0c;介绍怎么定位和解决这类问题。 根据top命令&#xff0c;发现PID为28555的Java进程占用CPU高达200%&#xff0c;出现故障。 …

Java并发编程实战 代码bug,Java并发编程实战(1)- 并发程序的bug源头

概述并发编程一般属于编程进阶部分的知识&#xff0c;它会涉及到很多底层知识&#xff0c;包括操作系统。编写正确的并发程序是一件很困难的事情&#xff0c;由并发导致的bug&#xff0c;有时很难排查或者重现&#xff0c;这需要我们理解并发的本质&#xff0c;深入分析Bug的源…

ajax小结

转载于:https://www.cnblogs.com/infernoyy/p/7250548.html

linux mysql迁移,Linux 下安装MySQL并迁移备份

简单记录下在centOS上安装MySQL(MariaDB)的过程。这里我并没有选择特定的MySQL版本&#xff0c;使用的是源默认提供的版本。1. 执行安装命令&#xff1a;执行如下指令安装MySQL数据库。1yuminstall-ymysqlmysql-server注意这里同时安装了mysql和mysql-server。在输出一长串信息…

Asp.net--DropDownList控件绑定数据库数据

DropDownList控件绑定数据库数据&#xff1a;DB是公共类&#xff0c;reDt是公共类中的方法 放在Page_Load事件中 if (!IsPostBack){DB db new DB();DataTable dt db.reDt("select * from provinceInfo order by provinceid asc");ddlsmprovince.DataSource dt;ddl…

app推送以及提示音java,springboot 整合 Jpush 极光推送

产品简介&#xff1a;JPush 是经过考验的大规模 App 推送平台&#xff0c;每天推送消息数超过 5 亿条。 开发者集成 SDK 后&#xff0c;可以通过调用 API 推送消息。同时&#xff0c;JPush 提供可视化的 web 端控制台发送通知&#xff0c;统计分析推送效果。 JPush 全面支持 An…

C++游戏系列2:角色装备武器

很多其它见&#xff1a;C游戏系列文件夹 知识点&#xff1a;类的组合&#xff0c;A类的数据成员。是B类的对象&#xff0c;或B类的对象。做A类的数据成员    【项目-带武器的游戏角色】   设计一个武器类&#xff0c;其数据成员至少要有武器名、威力&#xff0c;还能够…

php 显示当前年月日时分秒,php 获取当前前后年、月、星期、日、时分秒的时间...

php 获取今天前后年、月、星期、日、时分秒的时间。通过设置时间戳函数strtotime()的参数获取时间。//获取当前时间echo date(Y-m-d H:i:s,strtotime(now));echo date(Y-m-d H:i:s);echo date(Y-m-d H:i:s,time());//获取5天前的时间echo date(Y-m-d H:i:s,strtotime("-5 …

Lydsy2017年4月月赛 抵制克苏恩

Description小Q同学现在沉迷炉石传说不能自拔。他发现一张名为克苏恩的牌很不公平。如果你不玩炉石传说&#xff0c;不必担心&#xff0c;小Q同学会告诉你所有相关的细节。炉石传说是这样的一个游戏&#xff0c;每个玩家拥有一个30 点血量的英雄&#xff0c;并且可以用牌召唤至…

php 判斷數據庫表是否存在,phpl判斷mysq數據庫中的某個數據表是否存在的方法總結...

注意&#xff1a;以下都是在ThinkPHP框架中進行測試方式1通過查詢MySQL的配置表信息//TABLE_SCHEMA&#xff1a;表示數據庫名 &#xff0c; TABLE_NAME : 表示表名$sql "SELECT count(*) FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMAdatabase_name and TABLE_NAME…

怎样学习(3):迭代学习,精益求精

古人云「十年寒窗无人问。一举成名天下知」&#xff0c;这是中国古代为数不多的读书人的真实写照。大多数读书人仅仅有十年寒窗&#xff0c;却不见得成名。 在软件开发领域有瀑布模式的软件project方法论。它将软开发的几个过程「需求分析&#xff0c;概要设计&#xff0c;具体…

matlab宏参赛,MATLAB杯无人机大赛 | 决赛通知!

原标题&#xff1a;MATLAB杯无人机大赛 | 决赛通知&#xff01;重磅消息——决赛通知&#xff01;经过近5个多月的准备&#xff0c;MATLAB杯无人机比赛即将迎来精彩的决赛&#xff0c;来自全国10强的参赛队伍&#xff0c;齐聚羊城广州&#xff0c;美丽的中山大学&#xff0c;进…

action中写php函数,WordPress中add_action(将函数连接到指定action)

WordPress中add_action(将函数连接到指定action)首先说下WordPress中用的钩子,将一个函数&#xff0c;以一个新的动作命名&#xff0c;该函数就是语法&#xff1a;123add_action($tag,$function_to_add,$priority,$accepted_args);?>参数&#xff1a;$tag(字符串)(必填)$fu…

selenium之截图

selenium支持对当前页面保存截图&#xff0c;使用方法&#xff1a; driver.get_screenshot_as_file(file_path) 代码举例&#xff1a; ...... def get_screenshot(driver, path):保存页面截图n 0if path:passelse:path "D:\\test_data\\screenshot\\error_png.png"…

java excel类库,jExcelApi Java 操作 Excel 的类库

jExcelApi Java 操作 Excel 的类库Java Excel API(JXL)是一个成熟&#xff0c;开源的用来操作Excel电子表格的Java类库&#xff0c;支持读取&#xff0c;修改&#xff0c;写入等操作。这个项目基于GPL发布,而且对中文有很好的支持。● 支持字体、数字、日期操作● 能够修饰单元…