【U+B+D】三层框架 原理+实例

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

一、基本概况

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>


三、分层的优点

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


四、个人感受

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

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


原文地址:https://www.cnblogs.com/hhx626/p/6010459.html