zoukankan      html  css  js  c++  java
  • 软件开发三层构架解析

    TraceBack 网络
    整理者:赵岩

    1. 三层应该是 “逻辑”三层,在设计上分为三层,但不一定必须好像要有三个文件那样

    2. C/S 跟是不是三层没有关系,三层是指你对系统的逻辑规划,要有最顶层的Application,要有中间的业务逻辑和业务实体,要有底层的数据访问。举个例子,你用客户端的一个程序去访问数据库,首先这个 client 可以看成顶层,那么就算你是直接链接的数据库,在使用 DataSet 取得数据后你也不能直接让 UI 去负责显示了啊,你总要设计中间的一层,就是业务逻辑层。

    一定不能是实现成这样:
    private void button1_Click(object sender,EventArgs e)
    {
      SqlConnection conn = .......;
      conn.Open();
      DataTable table = adapter.GetData();
      this.dataGridView1.DataSource = table;
    }

    此乃兵家大..大大...大...大...大...忌。不能你一个“按钮”就直接控制了访问数据库、取数据、显示,那就变成一层了。
    参考实现成:
    UI层
    private void button1_Click(object sender,EventArgs e)
    {
      学生实体 entity = 业务逻辑层.Get学生实体();
      textBox1.Text = entity.姓名;
      textBox2.Text = entity.年龄.ToString();
    }
    业务逻辑层,定义一个类或 DLL
    public 学生实体 Get学生实体()
    {
      数据访问层结构 data = 数据访问层.GetData();
      学生实体 entity = new 学生实体();
      entity.姓名 = data.Row[0].ToString();
      ...
    }
    数据访问层
    public 数据访问层结构 GetData()
    {
      SqlConnection conn = .......;
      conn.Open();
      DataTable table = adapter.GetData();
      ....
    }
    以上举个小例子,这样,逻辑上分为了三层,数据层只负责对数据库的操作,逻辑层作为桥梁让上层更专注本身的业务结构,比如一个学生管理,对用户(UI)来说,每一个学生作为一个实体对它才是有意义的,而不是 DataTable.Row[0][1].ToString()的值是什么。所以逻辑层封装好了对上层有意义的数据结构,返回给上层。而 UI 只负责将这种有意义的实体做显示操作,并响应用户操作,告诉下层“我要获取一个”,“我要添加一个”,“我要修改一个”。

    因此,C/S 架构和是不是三层没有什么逻辑关联,你可以将三层全部放在 C 端,但是由数据访问层去访问数据库。C/S 是你部署和运行的方式,三层是你对软件的架构方式。

    作者:不老神仙
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    Flutter Android ERROR: ensureInitializationComplete must be called after startInitialization
    MySQL 创建用户表和好友表
    Android 广播的使用 文档使用的是 kotlin版本
    Flutter 分段器的使用
    Flutter 计算两个日期之间相差多少天,生成区间随机数
    Flutter 多环境
    Android ListView 的使用 Kotlin
    Android 自定义控件----基础
    Flutter 学习(3)------------通过List或者map循环数据渲染页面。。
    vs2015 编译报错:The project references NuGet package(s) that are missing on this computer...
  • 原文地址:https://www.cnblogs.com/allanbolt/p/1489581.html
Copyright © 2011-2022 走看看