机房重构之配置文件、反射和抽象工厂

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

    本次机房重构过程中用到了反射 配置文件,目的还是挺明确的:就是为了更换数据时方便,遵循开放 封闭原则,解决了可维护和可扩展的问题。

     以下就重构机房登录为例来看看配置文件 反射的用法。机房收费系统登录用到的数据库表是 User_info 表(用户表)。


 下面看看配置文件 反射 抽象工厂在登录时访问数据库 User 表时的用法:

     1. 先进行配置文件操作

    步骤:( )在 VS 资源管理器的项目 UI 中,打开App.config 文件。



      )在配置文件中添加参数


     分析:在配置文件中写明是 SQLServer 还是 Access ,防止更改应用程序中的代码,利于扩展,避免修改。

     )在要用到配置文件的项目中添加引用 System .configuration (在机房重构中Factroy 项目用到了配置文件):在 Factroy 中选择添加引用


 )引用界面如下:


 在左边“程序集”栏中找到“框架”从右边找到“ System .configuration ”这项勾选上。这样配置文件基本就完成!

 2. 反射 配置文件 抽象工厂代码(访问 SQLServer 中重构机房的用户( User 表))

  (1)添加代码

<span style="font-size:18px;">'*************************************************
 
Imports System.Reflection   '添加反射的引用
Imports System.Configuration   '添加配置文件的引用
Imports IDAL
 
Public Class SqlServerFactory
  '利用反射+配置文件+抽象工厂
  Private Shared ReadOnly AssemblyName As String = "DAL"      '定义程序集名称变量,D层命名空间的名字
  Private Shared db As String = ConfigurationManager.AppSettings("DB") '表示读取配置文件,如果配置文件中是Sqlserver,就访问SQLServer数据库,如果是别的就访问别的,不用更改程序中的代码。
 
  '创建用户表的工厂
  Public Function CreateUserInfo() As IUser
    Dim className As String = AssemblyName + "." + db + "UserDAL"          ' AssemblyName是程序集的名称,db + "UserDAL"是DAL层中的SqlServerUserDAL的类名。之所以配置文件中写Sqlserver ,是因为DAL层中类名是SqlServerUserDAL。如果不用SqlServer数据库,那么我在Factroy中再另建一个类,比如访问Access数据库,那么类名就叫AccessUserDAL。把配置文件中的Value值改为Access。这样就是扩展而不是修改。
    Dim iuser As IUser   '实例化接口IUser
 
    iuser = CType(Assembly.Load(AssemblyName).CreateInstance(className), IUser)
’将实例化的D层类通过向上转型转换成接口类,然后通过调用接口类中的函数来调用D层中实现该接口的函数。
    Return iuser
  End Function
 
End Class</span>

    分析: DAL  层中的类名是根据自己情况起的,不必一定前面加上   Sqlserver  或者   Access  。只要是一个标志,标识成这个类的代码是访问的  S QLServer  数据库,这个类的代码是访问的   Access  数据库的就行。配置文件根据情况更改就行。

(2)为什么要用抽象工厂

以备我们的软件要在不同数据库上运行,现在我们使用的是SQL Sever,而要使用Access或者Oracle等时就需要考虑了,抽象工厂可以使我们灵活地更换到其他数据库上。如何能够灵活结合UML图进行理解:

图中的蓝色框是IDAL(接口)




学习小结:

由于重构机房的这部分的应用,有一点时间了,感觉自己总是总结不好,就一直没有写,而现在感觉回过头来,再写一写总结感觉还是很不错的,至少又有了很多的感触。这部分虽然当时感觉蛮难搞定的的,花了不少的时间来处理,现在还是很好理解的,努力去实践吧!


目录
相关文章
|
算法 自动驾驶 数据挖掘
3D检测:DETR3D
3D检测:DETR3D
707 0
3D检测:DETR3D
|
12月前
|
小程序 数据可视化 前端开发
编写小程序用什么软件
编写小程序用什么软件
736 5
|
缓存 JavaScript 前端开发
「offer来了」从基础到进阶原理,从vue2到vue3,48个知识点保姆级带你巩固vuejs知识体系
该文章全面覆盖了Vue.js从基础知识到进阶原理的48个核心知识点,包括Vue CLI项目结构、组件生命周期、响应式原理、Composition API的使用等内容,并针对Vue 2与Vue 3的不同特性进行了详细对比与讲解。
410 13
「offer来了」从基础到进阶原理,从vue2到vue3,48个知识点保姆级带你巩固vuejs知识体系
|
数据采集 数据可视化 数据挖掘
Python量化炒股常用的Pandas包
Python量化炒股常用的Pandas包
249 7
|
机器学习/深度学习 自然语言处理 搜索推荐
基于图神经网络的电商购买预测
基于图神经网络的电商购买预测
|
数据采集 自然语言处理 API
百度飞桨(PaddlePaddle)-数字识别
百度飞桨(PaddlePaddle)-数字识别
215 1
|
XML 存储 文件存储
LabVIEW使用自定义模板和示例项目来开发LabVIEW项目
LabVIEW使用自定义模板和示例项目来开发LabVIEW项目
157 0
|
前端开发 JavaScript 开发者
前端祖传三件套HTML的常用属性之class
HTML是前端开发的基础知识之一,而class属性是其中一个常用的属性。在HTML中,class属性可以帮助我们快速地为元素设置样式或者在JavaScript中通过类名找到元素并进行操作。本文将介绍class属性的定义、用法以及注意事项,帮助广大前端开发者更好地掌握class属性。
569 0
|
JavaScript 前端开发 jenkins
Jenkins + Github + Nginx 自动化部署 Vue 项目
Jenkins + Github + Nginx 自动化部署 Vue 项目,看起来好像 Jenkins 非常复杂,但其实只要自己多实操几次,一次又一次的去想如何偷懒,你就可以一步一步发现更多的知识点。
981 0
Jenkins + Github + Nginx 自动化部署 Vue 项目
|
编解码 索引 视频直播
第一个将Palette Mode引入VVC(H.266),阿里云在JVET会议上引起关注
本文作者阿里云视频云高级技术专家睿柯如是说:阿里云在屏幕视频编码技术和应用上有世界领先的团队。6月中国AVS会议中,阿里云提出提案分析屏幕视频编码的应用需求,引起AVS组织关注,采纳阿里云的提案成为下一代AVS3的需求。
5161 0
第一个将Palette Mode引入VVC(H.266),阿里云在JVET会议上引起关注