导读:三层的学习,也终于得到收获了。这个过程很艰辛,不止一次的想放弃。在这一个学习过程中,真的很感谢师傅的尽心、耐心、费心。其实真的很脆弱,现在回想起来都很不可思议。

一、基本概况

1,什么是三层

我们时常讨论的三层,指的是U层(User Iterface),也叫用户层、显示层;B层(Business Logic Layer),业务逻辑层;D层(Data Access Layer),数据访问层。

2,使用时机

不适用:业务逻辑简单,没有真正意义上的数据存储层

适用:业务逻辑复杂;数据存储到独立的介质。

注意:不是所有的系统都需要三层架构,不应为了分层而分层,从而增加开发负担。

3,各层的作用

U:向用户展现特定业务数据;采集用户的输入信息和操作。

B:从D层中获取数据,供U层显示用;从U层获取用户指令和数据,执行业务逻辑,并通过D层写入数据源。

D:从数据源加载数据(Select);向数据源写入数据(Insert、Update);从数据源删除数据(Delete)

4,基本原则

D:D层只提供基本的数据访问,不包含任何业务相关的逻辑处理;

U:只负责显示和采集用户操作,不包含任何的业务相关的逻辑处理;(界面设计:用户至上,兼顾简洁)

B:负责处理业务逻辑,同过获取U层传来的操作指令,决定执行业务逻辑,在需要访问数据源的时候直接交给D层处理,将处理结果返给U层。

5,引用关系

UI——BLL——DAL

说明:D层所在程序集不引用B层和U层;B层需要引用D层;U层直接引用B层,可能会间接引用D层。

二、具体实例(添加用户)

U层

<span style="font-family:KaiTi_GB2312;font-size:18px;">Private Sub btnOK_Click(sender As Object, e As EventArgs) Handles btnOK.Click

        '对密码进行确认
If txtEnsurePassword.Text.Trim = "" Then
MsgBox("请确认密码!")
txtEnsurePassword.Focus()
Exit Sub
End If
'确保用户密码不为空
If txtPassword.Text.Trim = "" Then
MsgBox("请输入密码!")
txtPassword.Focus()
Exit Sub
End If
'保证两次输入的密码一致
If txtEnsurePassword.Text.Trim <> txtPassword.Text.Trim Then
MsgBox("两次密码输入不一致,请重新输入!")
txtEnsurePassword.Focus()
Exit Sub
End If
'防止用户ID文本框为空
If txtUserID.Text.Trim = "" Then
MsgBox("请输入用户ID!")
txtUserID.Focus()
Exit Sub
End If
'用户名必须为数字
If IsNumeric(txtUserID.Text.Trim) = False Then
MsgBox("用户名必须为1-10个数字!")
txtUserID.Focus()
Exit Sub
End If
'添加用户的用户名不为空
If txtUserName.Text.Trim = "" Then
MsgBox("请输入姓名!")
txtUserName.Focus()
Exit Sub
End If
'保证添加的用户的级别不为空
If coboUserLevel.Text.Trim = "" Then
MsgBox("请选择用户级别!")
coboUserLevel.Focus()
Exit Sub
End If
'创建实体对象
Dim MyUser As Charge.Model.UserInfoModel = New Model.UserInfoModel
'对实体赋值
MyUser.UserID = txtUserID.Text.Trim
MyUser.PassWord = txtPassword.Text.Trim
MyUser.UserLevel = coboUserLevel.Text.Trim
MyUser.UserName = txtUserName.Text.Trim
'创建B层对象,并对返回值进行处理
Dim MyAddUser As Charge.BLL.AddUserBLL = New BLL.AddUserBLL
If MyAddUser.IsAddUser(MyUser) Then
MsgBox("该用户添加成功!")
Else
MsgBox("该用户名已经注册,请更改!")
End If</span>

B层

<span style="font-family:KaiTi_GB2312;font-size:18px;">'/**********************************************
'类名:AddUserBLL
'命名空间:Charge.BLL
'创建时间:2014/12/13 10:55:01
'创建人:HHX
'修改时间:
'修改人:
'版本号:v1.0.0
'版权:HHX
'/********************************************** Public Class AddUserBLL
''' <summary>
''' 首先对用户名进行遍历,避免重复,然后注册新用户!
''' </summary>
''' <remarks></remarks>
Dim AddUserD As Charge.DAL.AddUserDAL = New Charge.DAL.AddUserDAL Public Function IsAddUser(ByVal MyUser As Charge.Model.UserInfoModel) As Boolean '判断用户是否成功注册
Dim MyCheck As DataTable
MyCheck = AddUserD.Check(MyUser) If MyCheck.Rows.Count > 0 Then
'用户名重复,不予注册
Return False
Else '用户名不重复,对此用户进行注册
Dim MyAdd As Integer
MyAdd = AddUserD.Add(MyUser)
Return True
End If End Function End Class</span>

D层

<span style="font-family:KaiTi_GB2312;font-size:18px;">'/**********************************************
'类名:AddUser
'命名空间:Charge.DAL
'创建时间:2014/12/12 21:40:24
'创建人:HHX
'修改时间:
'修改人:
'版本号:v1.0.0
'版权:HHX
'/**********************************************
Imports System.Data.SqlClient
Imports System.Configuration Public Class AddUserDAL
''' <summary>
'''共两个方法,Check对用户名进行验证,Add添加新用户
''' </summary>
''' <param name="MyUser"></param>
''' <returns></returns>
''' <remarks></remarks>
Public Function Check(ByVal MyUser As Charge.Model.UserInfoModel) As DataTable '对新添加的用户进行用户名验证,避免用户名重复
Dim strSql As String
strSql = "select UserID from T_UserInfo where UserID=@UserID"
'给变量赋值
Dim SqlParams As SqlParameter() = {New SqlParameter("@UserId", MyUser.UserID)}
Dim MyHelper As SqlHelper = New SqlHelper
'进行查询
Return MyHelper.ExecSelect(strSql, CommandType.Text, SqlParams) End Function Public Function Add(ByVal MyUser As Charge.Model.UserInfoModel) '经过用户名验证成功后,进行用户添加
Dim strSql As String
strSql = "insert into T_UserInfo(UserID,PassWord,UserLevel,UserName) values(@UserID,@PassWord,@UserLevel,@UserName)"
'对变量进行赋值
Dim SqlParams As SqlParameter() = {New SqlParameter("@UserID", MyUser.UserID),
New SqlParameter("@PassWord", MyUser.PassWord),
New SqlParameter("@UserLevel", MyUser.UserLevel),
New SqlParameter("@UserName", MyUser.UserName)}
Dim MyHelper As SqlHelper = New SqlHelper
'执行
Return MyHelper.ExecAddDelUpdate(strSql, CommandType.Text, SqlParams) End Function End Class</span>

注:SqlHelper是一个封装数据库操作的类。

Model

<span style="font-family:KaiTi_GB2312;font-size:18px;">Public Class UserInfoModel

    '定义变量
Private strUserName As String
Private strPassword As String
Private strUserId As String
Private strUserLevel As String
Private strHead As String '可读写属性Username
Public Property UserName As String
Get
Return strUserName
End Get
Set(value As String)
strUserName = value
End Set End Property
'可读写属性Password
Public Property PassWord As String Get
Return strPassword
End Get
Set(value As String)
strPassword = value
End Set End Property
'可读写属性UserLevel
Public Property UserLevel As String Get
Return strUserLevel
End Get
Set(value As String)
strUserLevel = value
End Set End Property
'可读写属性Head
Public Property Head As String Get
Return strHead
End Get
Set(value As String)
strHead = value
End Set End Property
'可读写属性UserID
Public Property UserID As String Get
Return strUserId
End Get
Set(value As String)
strUserId = value
End Set End Property End Class
</span>

三、分层的优点

主要优点:解耦和,易于维护和合作(层与层之间分工明确)。


四、个人感受

学习三层真的挺痛苦的,不过熬过去了也就过去了。三层虽好,但也不能到处乱使,还得根据情况集体分析。

其次,在这个过程中,又发现了自己的一个大问题:我喜欢自己磨,我要磨个一两天,甚至的三四天,我要磨到我实在找不出方法来了,我才会去找别人交流。师傅说我这样费事儿,要多去和别人交流,可是我发现我改不过来,我也知道自己磨不好,但如果还有方法没有尝试过,我就是不愿意去找别人要一个答案。尽管师傅说我费事儿,但我发现我还是挺享受这个痛苦又甜蜜的过程的。不过,我以后会改。

【U+B+D】三层框架 原理+实例的更多相关文章

  1. 【EF 1】EF实体框架 原理+实例

    一.知识回顾 到目前为止,自己学到的链接数据库操作已经经历了几个阶段,分别是:学生信息管理和(第一次)机房收费时的直接连接数据库操作表格,然后是机房个人重构中应用的操作实体,在其中还利用了一个很重要的 ...

  2. day13(JSTL和自定义标签&MVC模型&javaweb三层框架)

    day13 JSTL标签库(重点) 自定义标签(理解) MVC设计模式(重点中的重点) Java三层框架(重点中的重点) JSTL标签库   1 什么是JSTL JSTL是apache对EL表达式的扩 ...

  3. ASP.NET动态网站制作(28)-- 三层框架(2)

    前言:三层框架的第二节课,继续上次课的内容. 内容: 1.三层框架的使用目的:可以将视图层和业务逻辑层及实体层分开,可以提高代码的扩展性,安全性,可以实现程序的低耦合性. 2.GetModel方法及G ...

  4. JSP+JavaBean+Servlet工作原理实例…

    JSP+JavaBean+Servlet工作原理实例讲解 首先,JavaBean和Servlet虽都是Java程序,但是是完全不同的两个概念.引用mz3226960提出的MVC的概念,即M-model ...

  5. 【MVC 1】MVC+EF实体框架—原理解析

    导读:在之前,我们学过了三层框架,即:UI.BLL.DAL.我们将页面显示.逻辑处理和数据访问进行分层,避免了一层.两层的混乱.而后,我们又在经典三层的基础上,应用设计模式:外观.抽象工厂+反射,使得 ...

  6. kbmMemTable关于内存表的使用,以及各种三层框架的评价

    关于内存表的使用(kbmMemTable) 关于内存表的使用说明一. Delphi使用内存表1.1 Delphi创建内存表步骤:1. 创建一个Ttable实例.2. 设置一个DataBaseName为 ...

  7. ASP.NET Core 6框架揭秘实例演示[28]:自定义一个服务器

    作为ASP.NET Core请求处理管道的"龙头"的服务器负责监听和接收请求并最终完成对请求的响应.它将原始的请求上下文描述为相应的特性(Feature),并以此将HttpCont ...

  8. 学习笔记_Java_day12_设计模式MVC(13).JavaWeb的三层框架(14)

    MVC 1. 什么是MVC MVC模式(Model-View-Controller)是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控制器(Contr ...

  9. spring原理案例-基本项目搭建 03 创建工程运行测试 spring ioc原理实例示例

    下面开始项目的搭建 使用 Java EE - Eclipse 新建一 Dynamic Web Project Target Runtime 选 Apache Tomcat 7.0(不要选 Apache ...

随机推荐

  1. mysql> set sql_mode='no_auto_value_on_zero';

    mysql> set sql_mode='no_auto_value_on_zero';

  2. 【数据库-Azure SQL Database】如何创建事务复制将本地数据同步到 SQL Azure

    Azure SQL DB 可以被配置成为 SQL Server 事务复制的一个订阅者( subscriber ). 主要应用场景有两种: 将您的数据迁移到 Azure SQL DB, 并且没有宕机时间 ...

  3. C# DataTable的詳細用法 (转)

    在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 一.DataTable简 ...

  4. Android学习总结(十一)———— Adapter的使用

    一.Adapter的基本概念 UI控件都是跟Adapter(适配器)打交道的,了解并学会使用这个Adapter很重要, Adapter是用来帮助填充数据的中间桥梁,简单点说就是:将各种数据以合适的形式 ...

  5. 如何在腾讯云上安装Cloud Foundry

    Cloud Foundry是VMware推出的业界第一个开源PaaS云平台,它支持多种框架.语言.运行时环境.云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的 ...

  6. ssh的server安装和安装指定版本的软件的方法

    ssh程序分为有客户端程序openssh-client和服务端程序openssh-server.如果需要ssh登陆到别的电脑,需要安装openssh-client,该程序ubuntu是默认安装的.而如 ...

  7. POI读word doc 03 文件的两种方法

    Apache poi的hwpf模块是专门用来对word doc文件进行读写操作的.在hwpf里面我们使用HWPFDocument来表示一个word doc文档.在HWPFDocument里面有这么几个 ...

  8. 【转】Java重构-策略模式、状态模式、卫语句

    前言 当代码中出现多重if-else语句或者switch语句时.弊端之一:如果这样的代码出现在多处,那么一旦出现需求变更,就需要把所有地方的if-else或者switch代码进行更改,要是遗漏了某一处 ...

  9. Xcode中的约束用法

    这篇文章用几个简单的例子来介绍XCode6.1故事板中约束的使用方法.   现在iOS设备屏幕的尺寸也有很多种了,尤其是有了iPhone6 Plus以后,再不关注界面的尺寸适配就有点说不过去了.   ...

  10. windows 7虚拟机与主机不能互ping通,但是都能与网关ping通

    这里是在Windows 10的环境下使用VMware安装了一个Windows 7的虚拟机,虚拟机中是使用桥接的方式.结果发现虚拟机不能与物理机互通,但是却能与网关互通.查看虚拟机和物理机的IP发现都是 ...