设计模式之四(抽象工厂模式第二回合)
前言
在第一回合中留下的问题,http://www.cnblogs.com/aehyok/archive/2013/05/19/3087497.html,现在就先处理一个简单的,只添加一个Department表。
第二回合
首先要建立部门类,假设只有两个字段部门ID,和部门名称。
public class Department { public int ID { get; set; } public string DeptName { get; set; } }
下面看一下添加了部门表的UML类图
IDpartment接口,用于客户端访问,解除与具体数据库访问的耦合。
interface IDepartment { void Insert(Department department); Department GetDepartment(int id); }
SqlServerDepartment类,用于访问Sql Server的Department.
public class SqlServerDepartment : IDepartment { public void Insert(Department department) { Console.WriteLine("在Sql Server中给Department表增加一条记录"); } public Department GetDepartment(int id) { Console.WriteLine("在Sql Server中根据ID得到Department表一条记录"); return null; } }
AccessDepartment类,用于访问Access的Departmet。
public class AccessDepartment : IDepartment { public void Insert(Department department) { Console.WriteLine("在Access中给Department表增加一条记录"); } public Department GetDepartment(int id) { Console.WriteLine("在Access中根据ID得到Department表一条记录"); return null; } }
IFactory接口,定义一个创建访问Department表对象的抽象的工厂接口。
interface IFactory { IUser CreateUser(); IDepartment CreateDepartment(); }
在IFactory接口中又新添加了CreateDepartment()接口方法
SqlServerFactory类,实现IFactory接口,主要是实现Sql Server数据库添加了的部门接口方法。
public class SqlServerFactory : IFactory { IUser IFactory.CreateUser() { return new SqlServerUser(); } public IDepartment CreateDepartment() { return new SqlServerDepartment(); } }
AccessFactory类,实现IFactory接口,主要是实现Access数据库添加了的部门接口方法。
public class AccessServerFavtory : IFactory { IUser IFactory.CreateUser() { return new AccessUser(); } public IDepartment CreateDepartment() { return new AccessDepartment(); } }
客户端代码
class Program { static void Main(string[] args) { User user = new User(); Department dept = new Department(); IFactory factory = new AccessFactory(); IUser iu=factory.CreateUser(); iu.Insert(user); iu.GetUser(1); IDepartment id = factory.CreateDepartment(); id.Insert(dept); id.GetDepartment(1); Console.ReadLine(); } }
现在如果想切换数据库,只需要IFactory factory = new AccessFactory();修改为IFactory factory=new SqlServerFactory();
只有一个Uer类和User操作类的时候,是只需要工厂方法模式的,但是现在显然你数据库中有很多的表,而Sql Server与Access又是两大不同的分类,所以解决这种涉及多个产品系列的问题,有一个专门的工厂模式叫抽象工厂模式。
总结
通过第一回合和第二回合的前奏,我们终于可以进入正题了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构