JDBC对于java的开发人员来说并不陌生,它封装了ODBC,简化了java连接数据库的开发,本文我从部分JDBC的源码入手来阐述一下JDBC。
桥接模式是由Gang of four整理的23种设计模式中的一种,JDBC是桥接模式一个典型的例子。了解JDBC源码,能让我们更好地理解桥接模式的意图和实现;了解桥接模式,能让我们更清楚JDBC设计的优越之处。
首先我们先来看下桥接模式的意图,它旨在将抽象部分与实现部分分离,使其可以独立地变化,废话不多说,我们直接看一张UML图:
其实最初我在看这句意图的时候非常的郁闷,作为一名开发人员,对抽象与实现的第一反应就是接口实现或者类继承,接口和实现类独立地变化本身就是一件让我觉得很郁闷的事情,但是看了这张UML图之后便恍然大悟了,这里的抽象与实现是聚合关系,也就是我们口头常说的调用者和被调用者,这样一来桥接模式的意图就很清楚了,其实某种意义上就是解耦了某个功能的抽象定义和具体实现,让其变成了两个互相独立的模块。
让我们回到JDBC的源码,首先请大家打开JDK API,翻到java.sql包:
可以发现,java.sql包不同于其他几乎所有的包,它基本可以说没有定义多少类,但是定义了大量的接口,而由各个数据库公司去写这些接口的实现类:
可以看到,sum公司仅仅是提出了一系列接口规范,数据库公司做出实现,然后当你真的需要连接某个数据库时,你需要先添加数据库公司发布的jar包,如jdbc-mysql.jar,然后在使用时先加载Driver:
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
System.out.println("找不到驱动程序类 ,加载驱动失败!");
e.printStackTrace();
}
然后就可以通过DriverManager去获取连接:
try {
conn = (Connection) DriverManager.getConnection(url , username , password );
} catch (SQLException e) {
System.out.println("数据库连接失败!");
e.printStackTrace();
} </