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