zoukankan      html  css  js  c++  java
  • 【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>


    三、分层的优点

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

    
    四、个人感受
    

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

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


  • 相关阅读:
    软件总结
    今日总结
    今日总结
    今日总结
    今日总结
    今日总结
    今日总结
    3.22
    3.21
    3.20
  • 原文地址:https://www.cnblogs.com/hhx626/p/6010459.html
Copyright © 2011-2022 走看看