设计模式之四(抽象工厂模式第二回合)
前言
在第一回合中留下的问题,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又是两大不同的分类,所以解决这种涉及多个产品系列的问题,有一个专门的工厂模式叫抽象工厂模式。
总结
通过第一回合和第二回合的前奏,我们终于可以进入正题了。