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