Java讀取properties檔案連線資料庫
先說為什麼要有這種東西,或者我們為什麼要用這種方式來寫,先看經常用的方法,我們經常寫的
package util;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class ConnectionManager {
public static Connection getConnection() {
Connection conn = null;
try {
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/mail";
String username = "root";
String password = "root";
conn = DriverManager.getConnection(url, username, password);
} catch (ClassNotFoundException e1) {
e1.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
}
相信剛接觸jdbc,用的都是這種方式,這種方式也是比較好理解的,載入驅動,帶著url,使用者名稱,密碼連線資料庫,程式碼簡單易懂。同時也帶來了一個最重要的問題,當有一天我們想要換資料庫的時候,怎麼辦?驅動也變了,什麼都變了,你可以說改程式碼啊,程式就是方便我們的,處理事情的方式越簡單越好,這樣更改程式碼的方式很low啊,也許我們只是改了四行程式碼。程式碼的複用性我們可能都沒有實現。
我們定義好一個配置檔案,讓程式來讀取這個檔案,這個程式是固定的,只是配置檔案我們自己來寫,這樣做的好處就是,我們在更改資料庫的時候,不需要更改程式碼,提高了程式碼的複用性。
先介紹一下propertie檔案: Java中的properties檔案是一種配置檔案,主要用於表達配置資訊,檔案型別為*.properties,格式為文字檔案,檔案的內容是格式是 "鍵=值"的格式。
可以理解為Map結構,鍵值對的方式儲存,可以根據鍵來找到值。下圖是java連線mysql時候需要的資訊(我的資料庫是mail,username和password都是root,讀者根據自己的資料庫來寫)。一個鍵對應一個值,用=連線。
在java中提供了一個專門處理properties檔案的類Properties,包括載入,讀取這些操作都已經定義好,我們只是呼叫即可
下面是利用工具類讀取properties檔案,利用了static靜態塊,properties配置檔案下載了src資料夾下,在寫路徑的時候注意一下
程式碼部分引用了http://blog.csdn.net/u013805360/article/details/45692495的
package util;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
public class JdbcUtil {
private static String dirverName;
private static String url;
private static String username;
private static String password;
// 利用靜態塊i,在類載入的時候就被執行
static{
try {
// 用流讀入properties配置檔案
InputStream inputStream = JdbcUtil.class.getClassLoader()
.getResourceAsStream("datebase.properties");
Properties properties = new Properties();
// 從輸入位元組流讀取屬性列表(鍵和元素對)
properties.load(inputStream);
// 用此屬性列表中指定的鍵搜尋屬性,獲取驅動,url,username,password
dirverName = properties.getProperty("driverName");
url = properties.getProperty("url");
username = properties.getProperty("username");
password = properties.getProperty("password");
System.out.println(dirverName);
System.out.println(url);
System.out.println(username);
System.out.println(password);
// 載入驅動
Class.forName(dirverName);
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
// 獲取資料庫連線
public static Connection getConnection() {
Connection conn=null;
try {
conn=DriverManager.getConnection(url, username, password);
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
//測試
public static void main(String[] args) {
JdbcUtil.getConnection();
}
}
輸出:
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/mail
root
root
這樣做,我們在想要換資料庫的時候只要把properties檔案中的值更改了就可以,程式碼是不需要修改的,因為jdbc是固定的。在其他的配置方面也可以使用這種方法,提高了程式碼的複用性
//—————————————————分隔線——————————————————————//
說一下在這裡的掉進的坑,找了好長時間,一直報著類找不到
配置檔案中的資訊都已經讀取到了,也是正確的,jar包也在,把jar刪了重新匯入也不行……再看看properties配置檔案恍然大悟……
怎麼Driver的後面怎麼不一樣,滑鼠點上去,兩個空格!!!,把這兩個空格刪了,正常執行沒有拋異常,由於是字串中也是可以
有空格的所以讀取到的驅動後面都是帶兩個空格的,哪裡有後面帶兩個空格的驅動啊……
建議把之前的程式碼讀取配置檔案屬性的方法最後加上trim()方法去掉空格
dirverName = properties.getProperty("driverName").trim();
url = properties.getProperty("url").trim();
username = properties.getProperty("username").trim();
password = properties.getProperty("password").trim();
相關文章
- java Spring讀取properties檔案的注意點JavaSpring
- Java讀取properties配置檔案工具包Java
- mybatis讀取properties檔案內容MyBatis
- 織夢CMS(dedecms)的資料庫連線檔案_織夢連線資料庫檔案資料庫
- 使用openpyxl庫讀取Excel檔案資料Excel
- 網站連線資料庫配置檔案網站資料庫
- 配置檔案讀取——MySQL 多個連線MySql
- pandas的基礎使用,資料庫連線,檔案讀取,切片的使用等基本操作----01資料庫
- Spring boot 讀取properties檔案的四種方式Spring Boot
- SpringBoot--SpringBoot 讀取Properties檔案(結合JDBC)Spring BootJDBC
- 讀取resources中properties檔案內容範例
- java連線資料庫Java資料庫
- Java 讀取檔案Java
- 讀取資料夾檔案
- 工具類,關於手工讀取 properties檔案引數
- iis連線資料庫的檔案是哪個資料庫
- 使用yaml檔案讀取資料YAML
- EasyExcel庫來讀取指定Excel檔案中的資料Excel
- Java 對 properties 檔案操作 (ResourceBundle 類和 Properties 類)Java
- java中讀取配置檔案Java
- Java系列:讀取XML檔案JavaXML
- 輕鬆找到並檢視織夢CMS的資料庫配置檔案,從而獲取資料庫連線資訊資料庫
- Java 資料庫連線的那些事Java資料庫
- Java Druid資料庫連線池+SpringJDBCJavaUI資料庫SpringJDBC
- SpringBoot專案連線MySQL資料庫Spring BootMySql資料庫
- 好程式設計師Java培訓分享Java讀寫Properties配置檔案程式設計師Java
- Java專案連線資料庫Mysql報錯create connection SQLExceptionJava資料庫MySqlException
- Java讀取Json檔案工具類JavaJSON
- 1.6.5.2. 通過密碼檔案驗證連線資料庫密碼資料庫
- golang讀取檔案的json資料流,並解析到struct,儲存到資料庫GolangJSONStruct資料庫
- 4.SpringBoot中採用什麼方式進行配置專案檔案?SpringBoot如何讀取配置檔案中連線資料庫的資料?嘻哈的簡寫筆記——SpringBootSpring Boot資料庫筆記
- Django 直接使用資料庫連線和遊標讀寫資料庫Django資料庫
- 用Navicat連線資料庫-資料庫連線(MySQL演示)資料庫MySql
- 連線資料庫資料庫
- gin框架,讀取檔案的json資料流,並解析到struct,儲存到資料庫框架JSONStruct資料庫
- Java實時讀取日誌檔案Java
- java讀取大檔案並處理Java
- Java 讀取txt檔案生成Word文件Java