【抽象工厂模式】数据访问程序必须要更换DB吗

举报
Laura_张 发表于 2022/08/27 23:36:09 2022/08/27
【摘要】 文章目录 工厂方法模式的数据访问程序结构图:代码: 抽象工厂模式的数据访问程序结构图代码: 抽象工厂模式:优点和缺点: 简单工厂改进抽象工厂结构图 反射+抽象工厂反射...


更换数据库惹出来的麻烦。 SQL Server和Access的命名空间、对象、方法、函数和字段有很多不一样的地方,如果更换数据库的话,就需要更改数据库和程序代码,这样会无形中增加很多的工作量.

下面就数据访问程序来做一下更改。

工厂方法模式的数据访问程序

工厂方法模式是定义一个用于创建对象的接口,让子类决定实例化哪一个类。

结构图:

在这里插入图片描述

代码:

IUser接口,用来客户端访问,解除与具体数据库访问的耦合。
SQL ServerUser类,用来访问SQL Server的User。
IFactory接口,定义一个创建访问USer表对象的抽象的工厂接口。
SQLServerFactory类,实现IFactory接口,实例化SQLServerUser。

抽象工厂模式的数据访问程序

结构图

在这里插入图片描述

代码:

IDepartment接口,用于客户端访问,解除与具体数据库访问的耦合。
SQLServerDepartment类,用于访问SQLServer的Department
IFactory接口,定义一个创建访问Department表对象的抽象的工厂接口。
SQLServerFactory类,实现IFactory接口,实例化SQLServerUser和SQLServerDepartment
IUser接口,用于客户端访问,解除与具体数据库访问的耦合
SQLServerUSer类,用于访问SQLServer的User

抽象工厂模式:

抽象工厂模式:
提供一个创建一系列相关或相互依赖对象的接口,而无需指定他们具体的类。

AbstractProductA和B是两个抽象产品(他们可能有两种不同的实现,所以叫抽象)。
ProductA1 A2和B1 B2是对两个抽象产品的具体分类的实现。
IFactory是一个抽象工厂的接口,他里面应该包含所有的产品创建的抽象方法,ConcreteFactory1和2就是具体的工厂。

通常在运行时刻再创建一个ConcreteFactory类的实例,这个具体的工厂再创建具有特定实现的产品对象,也就是说,为创建不同的产品对象,客户端应该使用不同的具体工厂。

优点和缺点:

优点:
易于交换产品系列,由于工厂类,在一个应用中只需要在初始化的时候出现一次,这就使得改变一个应用的具体工厂变得非常容易,它只需要改变具体工厂即可使用不同的产品配置。

它让具体的创建实力过程与客户端分离,客户端是通过他们的抽象接口操纵实例,产品的具体类名也被具体弓藏的实现分离,不会出现在客户代码中。

缺点:
增加功能的时候,改动的地方比较多。

简单工厂改进抽象工厂

去除IFactory、SQLServerFactory、AccessFactory三个工厂类,将上面的三个工厂类取代为DataAccess类,用一个简单工厂模式来实现。

结构图

在这里插入图片描述

反射+抽象工厂

反射:

在这里插入图片描述
程序顶端写using System.Reflection;来引用Reflection
在这里插入图片描述

代码:

       private static readonly string AssemblyName = "抽象工厂模式";
       private static readonly string db = "Sqlserver";//数据库名称,可以替换成Access

        /// <summary>
        /// 这里是使用反射之后的样子
        /// </summary>
        /// <returns></returns>
        /// 使用反射需要加入命名空间:using System.Reflection;//引入反射
        public static IUser CreateUser()
        {
            string className = AssemblyName + "." + db + "User";
            return (IUser)Assembly.Load(AssemblyName).CreateInstance(className);
        }
        public static IDepartment  CreateDepartment()
        {
            string className = AssemblyName + "." + db + "Department";
            return (IDepartment)Assembly.Load(AssemblyName).CreateInstance(className);
        }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

反射+配置文件

使用反射+抽象工厂模式解决了数据库访问时的可维护、可扩展的问题。
所有在用简单工厂的地方,可以考虑用反射技术来去除switch或者if,解除分支判断带来的耦合。

添加配置文件App.config

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.7.2" />
    </startup>
	
	<!--在配置文件中更改,可以换成其他的数据库-->
	<appSettings>
		<add key="DB" value ="Sqlserver"/>
	</appSettings>
</configuration>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

还需要在程序的开头添加引用

using System.Reflection;//引入反射
using System.Configuration;//引用配置文件需要增加的地方

  
 
  • 1
  • 2
        //使用配置文件之后更改的样子
		//这里表示读取配置文件
        private static readonly string db = ConfigurationManager.AppSettings["DB"];

  
 
  • 1
  • 2
  • 3
编程是一门技术,大批量的改动,是一件非常丑陋的做法。

文章来源: blog.csdn.net,作者:张艳伟_Laura,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/Laura__zhang/article/details/113765907

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。