Interface Sample

数据库存在多种,我们可以将系统中所有对数据库的操作抽象出来,写成一个个方法组合到一个类.

简要说明:
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,程序不用做任何改动,真正的无逢移植。不过这样,本文所提到的方法就没什么用了.

come from:http://www.codesky.net/article/doc/200409/200409071018181.htm

猜你喜欢

转载自hanmo110.iteye.com/blog/1077831