Interface Sample

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

简要说明:

OracleDataOperate、SqlserverDataOperate、MysqlDataOperate,分别代表Oracle、Sqlserver、Mysql这三种数据库的操作类。继承自AbstractDataOperate

AbstractDataOperate是一个抽象类,包含了那些不同种类数据库都是一样代码的操作方法。继承自DataOperate

DataOperate是上面说的数据操作类的统一接口,只有两个方法:取得一条记录、插入一条记录。

DataOperateFactory是一个工厂方法,统一用它的方法来得到数据库操作类的实例。

SampleClass是我们系统的某个功能模块的类。

People是一个实体类,代表一条记录。三个字段 oid唯一标识符、name姓名、date生日。

详细说明:

1、所有系统功能模块类只认DataOperat这个接口还不必管具体的实现类是OracleDataOperate还SqlserverDataOperate。DataOperate源代码如下:

publicinterfaceDataOperate{

//根据记录的唯一标识取出一条记录

PeoplegetPeople(Stringoid);

//插入一条记录

booleaninsertPeople(Peoplepeople);

}

2、AbstractDataOperate、OracleDataOperate、SqlserverDataOperate、MysqlDataOperate都是继承DataOperate接口的,没什么好说的,省略。

3、DataOperateFactory。我们看看工厂方法怎么写的。

publicclassDataOperateFactory{

publicstaticfinalintORACLE=0;//定义三个表示数据库类型的常量

publicstaticfinalintMYSQL=1;

publicstaticfinalintSQLSERVER=2;

privatestaticDataOperatedb;

privatestaticintdataType=MYSQL;

/**

*根据数据库类型(dataType)取得一个数据库操作类的实例,

*这里对DataOperate使用了单例模式,因为OracelDataOperate等都是无状态的工具类,

*所以整个系统只保留一个实例就行了。

*

*@return返回的是接口,客户端不必关心具体是用那个实现类

*/

publicstaticDataOperategetInstance(){

if(db==null){

if(dataType==ORACLE)//根据dateType返回相应的实现类

returnnewOracelDataOperate();

if(dataType==MYSQL)

returnnewMysqlDataOperate();

if(dataType==SQLSERVER)

returnnewSqlserverDataOperate();

}

returndb;

}

}

4、接下来就看看使用端是如何调用工厂方法和使用数据操作类的。

/**

*系统某个功能类

*/

publicclassSampleClass{

privateDataOperatedb;//声明一个数据库操作类,注意这里用的是接口噢

/**某方法*/

publicvoidsampleMethod(){

db=DataOperateFactory.getInstance();//得到单一实例

Peoplep=db.getPeople("123");//取得一条记录

db.insertPeople(p);//再插回去

}

}

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

总结:

从例子中我们可以看到什么是面向接口的编程方式。SampleClass使用数据操作类可以不必关心具体是那个类,只要是符合接口的都行

要实例?只须调用DataOperateFactory.getInstance()即可,其它的交于DataOperateFactory这个工厂来做吧,使用端什么都不用关心。

我们要支持新的数据库类型,只须要象OracelDataOperate那样,再写一个继承AbstractDataOperate的类即可,比如SysbaseDataOperate。然后到DataOperateFactory中加入相应代码即可。

如果我们想要可配置性更高,可以用privatestaticintdataType=MYSQL;中的值设置到一个文本文件中。

对于开发支持多种数据库的系统,强烈建议使用hibernate,我现在做的系统就是用hibernate的,开发时用Mysql,到要给客户时将数据库换了DB2,程序不用做任何改动,真正的无逢移植。不过这样,本文所提到的方法就没什么用了.

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

相关推荐