JDBC原理


在这里插入图片描述

1.面向接口编程

解耦合:降低程序的耦合度,提高程序的扩展力
多态机制就是典型的面向接口编程
Animal a = new Cat;
Animal a = new Dog();

2.模拟JDBC本质

(1)JDBC接口:

**
 * sun公司制定的接口
 */
public interface JDBC {
    /**
     * 连接数据库的方法
     */
    void getConnection();
}

(2) 3个数据库实现类(实现者)

MySQL实现类:

/**
 * MySql的数据库厂家负责编写jdbc接口的实现类
 */
public class MySQL implements JDBC {

    //具体这里的代码怎么写,我们不关心,对于java程序员没关系
    //这段代码涉及到Mysql底层数据库的实现原理
    @Override
    public void getConnection() {
        System.out.println("连接mysql数据库成功...");
    }
}

Oracle实现类:

/**
 * Oracle数据库厂家负责编写JDBC接口的实现类
 */
public class Oracle implements JDBC {
    @Override
    public void getConnection() {
        System.out.println("连接Oracle数据库成功....");
    }
}

SQLServer实现类:

/**
 * SqlServer的数据库厂家负责编写JDBC的实现类
 */
public class SqlServer implements JDBC {
    @Override
    public void getConnection() {
        System.out.println("连接SQLServer数据库成功...");
    }
}

(3)java程序员(调用者)

jdbc.properties配置文件:

className=Oracle
import java.util.ResourceBundle;

/**
 * java程序员
 * 不需要关心具体是哪个品牌的数据库,只需要面向JDBC接口编写代码
 * 面向接口编程,面向抽象编程,不要面向具体编程
 */
public class JavaProgrammer {
    public static void main(String[] args) throws ClassNotFoundException, IllegalAccessException, InstantiationException {
//        JDBC jdbc0 = new MySQL();
//        JDBC jdbc1 = new Oracle();
//        JDBC jdbc2 = new SqlServer();


        //创建对象可以通过反射机制

        /*
        ResourceBundle类用于读取属性文件,
        读取属性文件时可以直接指定属性文件的
        名称,指定名称时不需要文件的后缀
         */
        ResourceBundle bundle = ResourceBundle.getBundle("jdbc");
        String className = bundle.getString("className");
        Class c = Class.forName(className);
        JDBC jdbc = (JDBC)c.newInstance();

        jdbc.getConnection();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值