Java讀取properties文件鏈接數據庫

以前咱們在入門jdbc的時候,經常使用這種方法鏈接數據庫:java

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,格式爲文本文件,文件的內容是格式是 "鍵=值"的格式。mysql

能夠理解爲Map結構,鍵值對的方式存儲,能夠根據鍵來找到值。下圖是java鏈接mysql時候須要的信息(個人數據庫是mail,username和password都是root,讀者根據本身的數據庫來寫)。一個鍵對應一個值,用=鏈接。sql

配置信息

測試代碼:數據庫

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是固定的。在其餘的配置方面也能夠使用這種方法,提升了代碼的複用性url

相關文章
相關標籤/搜索