对数据库的操作一般包括连接、打开、使用、关闭等步骤,在数据库操作模板类中我们定义了connDB()、openDB()、useDB()、closeDB()四个方法分别对应这四个步骤。对于不同类型的数据库(如SQL Server和Oracle),其操作步骤都一致,只是连接数据库connDB()方法不同,现使用模板方法模式对其进行设计。

 

 java实现

package template;

public abstract class DBTemplate {
    public abstract void connDB();
    public void openDB(){
        System.out.println("打开数据库");
    }
    public void useDB(){
        System.out.println("使用数据库");
    }
    public void closeDB(){
        System.out.println("关闭数据库");
    }
    public void process(){
        this.connDB();
        this.openDB();
        this.useDB();
        this.closeDB();
    }
}
package template;

public class OracleDBOperator extends DBTemplate{
    @Override
    public void connDB() {
        System.out.println("连接oracle");
    }
}
package template;

public class SqlServerDBOperator extends DBTemplate{
    @Override
    public void connDB() {
        System.out.println("连接sql server");
    }
}
package template;

public class Client {
    public static void main(String[] args) {
        DBTemplate db1,db2;
        db1=new SqlServerDBOperator();
        db1.process();
        System.out.println("---------------");
        db2=new OracleDBOperator();
        db2.process();
    }
}

c++实现

#include<iostream>
using namespace std;
class DBTemplate{
public:
    virtual void connDB()=0;
    void openDB(){
        cout<<"打开数据库"<<endl;
    }
    void useDB(){
        cout<<"使用数据库"<<endl;
    }
    void closeDB(){
        cout<<"关闭数据库"<<endl;
    }
    void process(){
        this->connDB();
        this->openDB();
        this->useDB();
        this->closeDB();
    }
};
class SqlServerDB:public DBTemplate{
public:
    void connDB(){
        cout<<"连接sql server"<<endl;
    }
};
class OracleDB:public DBTemplate{
public:
    void connDB(){
        cout<<"连接oracle"<<endl;
    }
};
int main()
{
    DBTemplate *db1,*db2;
    db1=new SqlServerDB();
    db1->process();
    cout<<"-------------------"<<endl;
    db2=new OracleDB();
    db2->process();
    return 0;
}

 

原文地址:http://www.cnblogs.com/jzz-111jy/p/16925645.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性