• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
戈瑾
博客园    首页    新随笔    联系   管理    订阅  订阅
模板方法模式——java实现

问题描述:

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

类图:

 

Java代码:

//DBOperator.java
package shiyan24;

public abstract class DBOperator {
    public void process(){
        connDB();
        openDB();
        useDB();
        closeDB();
        }
    public abstract void connDB();
    public void openDB(){
        System.out.println("打开数据库");
        }
    public void useDB(){
        System.out.println("使用数据库");
        }
    public void closeDB(){
        System.out.println("关闭数据库");
        }
}
//SQLServerDB.java
package shiyan24;

public class SQLServerDB extends DBOperator{

    @Override
    public void connDB() {
        // TODO 自动生成的方法存根
        System.out.println("连接SQLServer数据库");
    }

}
//OracleDB.java
package shiyan24;

public class OracleDB extends DBOperator{

    @Override
    public void connDB() {
        // TODO 自动生成的方法存根
        System.out.println("连接Oracle数据库");
    }

}
//Client.java
package shiyan24;

import java.util.Scanner;
public class Client {
    public static void main(String[] args) {
        DBOperator db = null;
        System.out.println("请选择:1、SQLServer 2、Oracle");
        Scanner input=new Scanner(System.in);
        int i=input.nextInt();
        if(i==1) {
            db=new SQLServerDB();
        }else if(i==2) {
            db=new OracleDB();
        }
        db.process();
    }
}

 

运行结果:

 

 

 

posted on 2021-12-01 10:30  戈瑾  阅读(119)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3