由於使用DriverManager獲取數據庫連接時,由於DriverManager實現類中有一段靜態代碼塊,可以直接注冊驅動,且可以同時管理多個驅動程序
所以當換數據庫連接時需要指定不同的數據庫,那麼就需要反復修改properties配置文件(雖然並不麻煩),所以我想將每種驅動連接程序的properties文件都寫好
具體當進行連接時,再加一個配置文件,這個配置文件中指定傳入哪個properties文件
先來看一下文件路徑(圖片復制粘貼為何不好使了!!!!)
src
com.jdbc.java
TestJDBC.java
properties
jdbcName.properties
mySql.properties
反正大體是這樣了,第一層是包,下面是各種文件
代碼如下
/**
* 指定一個配置文件中進行選擇使用哪個配置文件(好繞口。。。)
*
* @return
* @throws Exception
*/
public Connection getConnection3() throws Exception {
// 准備連接數據庫的四個字符串
// 驅動的全類名
String driverClass = null;
String jdbcUrl = null;
String user = null;
String password = null;
String jdbcName = null;
// 讀取jdbcName.properties文件
InputStream inStream = getClass().getClassLoader().getResourceAsStream("properties/jdbcName.properties");
Properties propertiesOfName = new Properties();
propertiesOfName.load(inStream);
jdbcName = propertiesOfName.getProperty("jdbcName");
// 讀取需要的properties 文件
InputStream in = getClass().getClassLoader().
getResourceAsStream("properties/" + jdbcName + ".properties");
Properties properties = new Properties();
properties.load(in);
driverClass = properties.getProperty("driver");
jdbcUrl = properties.getProperty("jdbcUrl");
user = properties.getProperty("user");
password = properties.getProperty("password");
// 加載數據庫驅動程序(注冊驅動)
Class.forName(driverClass);
Connection connection = DriverManager.getConnection(jdbcUrl, user, password);
return connection;
}
測試代碼如下
@Test
public void testGetConnection3() throws Exception {
System.out.println(getConnection3());
}
結果如下
com.mysql.jdbc.JDBC4Connection@104a311
需注意的問題:這種方式指定properties文件時不能選擇相對路徑,會報錯
jdbcName.properties中的代碼如下
jdbcName=mySql
這裡的代碼是不是非常簡潔,只需把各種什麼mySql,Oracle之類的配置文件寫好,然後想用哪個來這個配置文件中把名字一改就行,改動非常小(懶人專用~)