作用
为了使得连接池为各个程序共用,而不是每个程序都申请一个连接池,可以定义一个工具类,使得有且仅提供一个连接池。
实现思路
在工具类的static块内创建数据库连接池对象即可,为使得类全局可用该对象,也同样定义个static属性以引用连接池对象,然后定义好getConnection()方法和close重载方法。最后提供一个返回工具类连接池的方法以供一些框架使用。
获取连接池对象
private static DataSource ds;
static {
Properties pro = new Properties();
try {
pro.load(JDBCUtils.class.getClassLoader().getResourceAsStream("DataSource/properties/durid.properties"));
ds = DruidDataSourceFactory.createDataSource(pro);
//c3p0直接new一个对象丢给ds
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
封装方法
public static void close(ResultSet rs, Statement stmt, Connection conn){
if (rs != null){
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (stmt != null){
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (conn != null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
public static void close(Statement stmt, Connection conn) {
close(null,stmt,conn);
}
public static DataSource getDataSource(){
return ds;
}