zoukankan      html  css  js  c++  java
  • 三层

    三层

    三层只是一个比较好的软件架构,不是非用三层不可。

    界面层UI(user interface);

    数据访问层DAL(Data Access Layer);

    业务逻辑层BLL(business logic layer )。实体类就是Model;对数据进行操作的代码写在DAL中,一般就是SQL语句,DAL只有对数据的操作,没有“如果金额大于20则不能删除”这样的逻辑;BLL调用DAL中的代码进行逻辑操作,比如“如果金额大于20则不能删除”。SQL语句、ADO.Net的类一般只应该出现在DAL中。

    先对比用SQLHelper和三层实现Age自增的区别。

    我们先做个SQLHelper自增

     

    一、设计好winform窗体

    下面我们直接添加配置文件和SqlHelper

    二、添加配置文件和SqlHelper

    三、添加引用

    四、添加配置文件

    这样的话配置文件和SqlHelper就都有了。

    首先想一下,要写之前还是要确定一下Sql语句。

    五、确定Sql语句

    六、VS代码

    七、SqlHelper执行结果

    接下来我们用三层实现年龄自动增长:

     

    八、写好winform窗体

    按照上一题的方法添加配置文件和SplHelper并添加引用。

    用三层写必须分的清清楚楚的。

    刚写好的winform窗体就可以理解成界面层UI。当然,也可以用ASP.NET的web页面来表现,或者手机页面。

    还需要一个数据访问层DAL,我们需要建个文件夹。

    九、添加DAL文件夹

    再建一个BLL凡是跟数据逻辑上有关系的都建在这里面。业务逻辑层BLL

     

    十、业务逻辑层BLL

    验证数据是否存在就属于业务逻辑。

    SqlHelper跟数据库打交道所以要把SqlHelper放到数据访问层DAL里面。

     

    十一、SqlHelper放到数据访问层DAL里

    接下来我要操作的是TblStudent这张表,我可能对这张表进行增删查改各种操作。所以,我建个类,就是对TblStudent表进行的操作。它是对数据访问层DAL,我们在TblStudent后面加个Dal。

     

    十二、TblStudentDal类

    十三、数据访问层的代码

    再创建个类是业务逻辑层。

    十四、业务逻辑层代码

    十五、界面层调业务逻辑层,业务逻辑层调数据访问层

    千万不能界面层直接调数据访问层,否则的话会造成很多的麻烦的。三层的目的就是分工明确,互不影响。

    最后,我们看下执行的效果。

    十六、执行后的效果

    先记住:配置文件是和界面层UI在一起的。等会我写案例,给大家演示一下。

    下面我们用三层校验用户名和密码。

    十七、设计好登录界面

    然后我们要确定Sql语句,怎么样判断用户名是否存在,密码是否正确呢?

    根据用户输入的用户名,找到密码

    如果找到密码,说明用户名存在;如果密码不存在说明用户名不存在。

    如果找到密码,验证一下是否正确,就可以判断是否登陆成功了。

    select     CC_AutoId,     CC_Loginpassword from T_Seats where CC_LoginId=@uid

    2.写数据访问层

    想一下执行完Sql语句返回的结果是什么呢?

    怎么把一条记录的多个列进行返回。

      数据访问层,返回一个对象。(需要用到Model)

    十八、写好Model

    十九、写好数据访问层

    数据访问层,根据用户名获取当前用户的基本信息。

    3.写业务逻辑层。在年龄自动增长中的业务逻辑层就是个打酱油的。

    这块的业务逻辑层就得有东西了。

    如何确定业务逻辑层的方法参数与返回值,根据表现层(调用者)的需求来确定。

    二十、写个枚举

    二十一、写好MD5

    二十二、写好业务逻辑层

    最后我们写界面层

    二十三、写好界面层

    好,看下最后的执行结果。

    二十四、最后显示效果

    接下来我们实现修改密码的功能:

    修改密码和我们ADO写过的需求一模一样。修改密码的按钮一开始是被禁用的。当成功之后,把登录的id记下来,修改密码按钮可用。当点它的时候再弹出一个窗口来,这个窗口是用来修改密码的。

     

    二十五、写好第一个窗体

     

    二十六、写好第二个窗体

    想想怎么实现这个功能?

    登录成功以后启动修改密码按钮,记住用户的id,得写个静态类。那么这个类写入哪一层呢?接下来就该确定下Sql语句,首先验证下输入新密码是否正确(与Sql无关),验证旧密码时与Sql有关。

    在做这个功能之前我们再看下三层的具体写法。

    UI → 表现层,数据的采集,与数据的展示。

    Bll → 业务逻辑层,与业务相关的所有逻辑判断与处理。

    Dal → 数据访问层,只是操作数据库的操作,把sql语句执行,返回相应的结果。(一般不建议做任何逻辑处理。)

    Model

    像上题中判断文本框是否为空,不能输入特殊的符号等要放在业务逻辑层。判断的是取出的数据是不是为空,不是文本框本身不是为空。

    写在界面层也行,但是我现在要把wins窗体换成web页面,界面层中的判断还得再写一遍。要是写在业务逻辑层的话,就只写界面层的代码就行了。

    像注册邮箱的判断都是JS的功劳,不是业务逻辑层的问题。

    二十七、JS判断

    二十八、界面层逻辑

    静态类在表现层

    二十九、把Id从业务逻辑层传出来

    三十、界面层代码

    运行看下现在的效果。这样做的好处是,不要等都写完再调试。谁都不是神,这样分步写,容易找出自己写的代码的错误。

    三十一、显示第一部分成果

    修改密码操作首先是要确定Sql语句执行过程,思路:两次输入的新密码是否一致,旧密码是否正确,然后修改密码。判断一致不需要Sql语句,判断旧密码是否正确需要我们写Sql语句。修改密码也要写Sql语句。

    1.确定旧密码是否正确的Sql语句

    autoId,oldpwd

    "select count(*) from T_Seats where cc_autoId=@autoid and cc_loginPassword=@pwd"

    下面我们写数据访问层,由于还是操作那张表,不需要新建一个类。

    三十二、数据访问层代码

    修改密码的操作也是一条Sql语句,

    三十三、数据访问层-修改密码代码

    好了数据访问层中的代码写完了,现在我们开始写业务逻辑层中的代码。

     

    三十四、业务逻辑层用到的枚举

    三十五、业务逻辑层中的代码

    三十六、三层架构图

    三十七、两个案例的流程图

    作者近期文章列表:

    C#基础教程(完全免费,献给代码爱好者的最好礼物。注:本作者分享自己精心整理的C#基础教程,无任何商业目的。
    希望与更多的代码爱好者交流心得,也请高手多多指点!!!)
    SQL数据库 ADO.net 数据库的应用图解一
    数据库的应用详解二
    面向过程,面向对象中高级 面向过程,面向对象的深入理解一
    面向过程,面向对象的深入理解二
    面向对象的深入理解三
    winform基础 Winform基础
    winform中常用的控件
    面向过程 三种循环的比较
    C#中的方法(上)
    我们常见的数组
    面向对象 思想的转变
    C#中超级好用的类
    C#中析构函数和命名空间的妙用
    C#中超级好用的字符串
    C#中如何快速处理字符串
    值类型和引用类型及其它
    ArrayList和HashTable妙用一
    ArrayList和HashTable妙用二
    文件管理File类
    多态
    C#中其它一些问题的小节
    GDI+ 这些年我收集的GDI+代码
    这些年我收集的GDI+代码2
    HTML概述 你不能忽视的HTML语言
    你不能忽视的HTML语言2精编篇
    你不能忽视的HTML语言3
    JavaScript基础 JavaScript基础一
  • 相关阅读:
    Hadoop学习笔记——配置文件
    Hive学习笔记——SerDe
    MapReduce中的OutputFormat
    Nginx 转发时的一个坑,运维居然让我背锅!!
    教你用 Netty 实现一个简单的 RPC!
    完整的支付系统整体架构!
    String 拼接一定会走 StringBuilder?
    腾讯牛逼!终于开源了自家的 Tencent JDK——Kona!!
    Java 数组转 List 的 3 种方式,哪种性能最牛?
    Spring Boot 2.4.0 发布,配置文件重大调整,不要乱升级!!
  • 原文地址:https://www.cnblogs.com/zysbk/p/2706194.html
Copyright © 2011-2022 走看看