我们都知道开闭原则即为对修改关闭,对拓展开放,那么对于实现既能通过DriverManager连接数据库,也能实现使用c3P0连接数据库,连接数据库的方式即为可变点
,我们只需要使用抽象类或者接口封装可变点,再将可变点的每一个具体实现方式用一个类去描述
封装可变点:获取连接对象
package JDBC; import java.sql.Connection; import java.sql.SQLException; public abstract class AbstractJDBCUtils { public abstract Connection getConnection() throws SQLException;//用于定义获取连接对象的抽象方法 //关闭资源的方法 ......... }
具体实现方式1:通过c3p0数据库连接池获取连接对象
package JDBC; import com.mchange.v2.c3p0.ComboPooledDataSource; import javax.sql.DataSource; import java.sql.Connection; import java.sql.SQLException; public class JDBCFromC3p0Source extends AbstractJDBCUtils{ //通过使用c3p0获取连接对象的方法 ....... } }
具体实现方式2:通过DriverManager获取连接对象
package JDBC; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class JDBCFromDriverManager extends AbstractJDBCUtils{ @Override public Connection getConnection() throws SQLException { //通过DriverManager获取连接对象的方法 } }