Factory

简要说明:
oracledataoperate、sqlserverdataoperate、mysqldataoperate,分别代表oracle、sqlserver、mysql这三种数据库的操作类。继承自abstractdataoperate
abstractdataoperate是一个抽象类,包含了那些不同种类数据库都是一样代码的操作方法。继承自dataoperate
dataoperate是上面说的数据操作类的统一接口,只有两个方法:取得一条记录、插入一条记录。
dataoperatefactory是一个工厂方法,统一用它的方法来得到数据库操作类的实例。
sampleclass是我们系统的某个功能模块的类。
people是一个实体类,代表一条记录。三个字段 oid唯一标识符、name姓名、date生日。

详细说明:
1、所有系统功能模块类只认dataoperat这个接口还不必管具体的实现类是oracledataoperate还sqlserverdataoperate。dataoperate源代码如下:
public interface dataoperate {
//根据记录的唯一标识取出一条记录
people getpeople(string oid);
//插入一条记录
boolean insertpeople(people people);
}

2、abstractdataoperate、oracledataoperate、sqlserverdataoperate、mysqldataoperate都是继承dataoperate接口的,没什么好说的,省略。

3、dataoperatefactory。我们看看工厂方法怎么写的。
public class dataoperatefactory {
public static final int oracle = 0; //定义三个表示数据库类型的常量
public static final int mysql = 1;
public static final int sqlserver = 2;

private static dataoperate db;
private static int datatype = mysql;
/**
* 根据数据库类型(datatype)取得一个数据库操作类的实例,
* 这里对dataoperate使用了单例模式,因为oraceldataoperate等都是无状态的工具类,
* 所以整个系统只保留一个实例就行了。
*
* @return 返回的是接口,客户端不必关心具体是用那个实现类
*/
public static dataoperate getinstance() {
if (db == null) {
if (datatype == oracle) //根据datetype返回相应的实现类
return new oraceldataoperate();
if (datatype == mysql)
return new mysqldataoperate();
if (datatype == sqlserver)
return new sqlserverdataoperate();
}
return db;
}
}

4、接下来就看看使用端是如何调用工厂方法和使用数据操作类的。
/**
* 系统某个功能类
*/
public class sampleclass {
private dataoperate db; //声明一个数据库操作类,注意这里用的是接口噢
/**某方法*/
public void samplemethod() {
db = dataoperatefactory.getinstance();//得到单一实例
people p = db.getpeople("123"); //取得一条记录
db.insertpeople(p);//再插回去
}
}

  我们发现sampleclass中根本没有出现oraceldataoperate、mysqldataoperate等的影子,这就是接口的威力。客户端不必针对oraceldataoperate等写不同的代码,它只关心dataoperate即可,具体要取那个类的逻辑就由dataoperatefactory负责了。

总结:
从例子中我们可以看到什么是面向接口的编程方式。sampleclass使用数据操作类可以不必关心具体是那个类,只要是符合接口的都行
要实例?只须调用dataoperatefactory.getinstance()即可,其它的交于dataoperatefactory这个工厂来做吧,使用端什么都不用关心。
我们要支持新的数据库类型,只须要象oraceldataoperate那样,再写一个继承abstractdataoperate的类即可,比如sysbasedataoperate。然后到dataoperatefactory中加入相应代码即可。
如果我们想要可配置性更高,可以用private static int datatype = mysql;中的值设置到一个文本文件中。
  对于开发支持多种数据库的系统,强烈建议使用hibernate,我现在做的系统就是用hibernate的,开发时用mysql,到要给客户时将数据库换了db2,程序不用做任何改动,真正的无逢移植。不过这样,本文所提到的方法就没什么用了.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值