Java讀取properties文件連接數(shù)據(jù)庫(kù)的方法示例
之前我們?cè)谌腴Tjdbc的時(shí)候,常用這種方法連接數(shù)據(jù)庫(kù):
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,用的都是這種方式,這種方式也是比較好理解的,加載驅(qū)動(dòng),帶著url,用戶名,密碼連接數(shù)據(jù)庫(kù),代碼簡(jiǎn)單易懂。同時(shí)也帶來(lái)了一個(gè)最重要的問(wèn)題,當(dāng)有一天我們想要換數(shù)據(jù)庫(kù)的時(shí)候,怎么辦?驅(qū)動(dòng)也變了,什么都變了,你可以說(shuō)改代碼啊,程序就是方便我們的,處理事情的方式越簡(jiǎn)單越好,這樣更改代碼的方式很low啊,也許我們只是改了四行代碼。代碼的復(fù)用性我們可能都沒(méi)有實(shí)現(xiàn)。
我們定義好一個(gè)配置文件,讓程序來(lái)讀取這個(gè)文件,這個(gè)程序是固定的,只是配置文件我們自己來(lái)寫(xiě),這樣做的好處就是,我
們?cè)诟臄?shù)據(jù)庫(kù)的時(shí)候,不需要更改代碼,提高了代碼的復(fù)用性。
先介紹一下propertie文件: Java中的properties文件是一種配置文件,主要用于表達(dá)配置信息,文件類型為*.properties,格式為文本文件,文件的內(nèi)容是格式是 "鍵=值"的格式。
可以理解為Map結(jié)構(gòu),鍵值對(duì)的方式存儲(chǔ),可以根據(jù)鍵來(lái)找到值。下圖是java連接mysql時(shí)候需要的信息(我的數(shù)據(jù)庫(kù)是mail,username和password都是root,讀者根據(jù)自己的數(shù)據(jù)庫(kù)來(lái)寫(xiě))。一個(gè)鍵對(duì)應(yīng)一個(gè)值,用=連接。

測(cè)試代碼:
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;
// 利用靜態(tài)塊i,在類加載的時(shí)候就被執(zhí)行
static{
try {
// 用流讀入properties配置文件
InputStream inputStream = JdbcUtil.class.getClassLoader()
.getResourceAsStream("datebase.properties");
Properties properties = new Properties();
// 從輸入字節(jié)流讀取屬性列表(鍵和元素對(duì))
properties.load(inputStream);
// 用此屬性列表中指定的鍵搜索屬性,獲取驅(qū)動(dòng),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);
// 加載驅(qū)動(dòng)
Class.forName(dirverName);
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
// 獲取數(shù)據(jù)庫(kù)連接
public static Connection getConnection() {
Connection conn=null;
try {
conn=DriverManager.getConnection(url, username, password);
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
//測(cè)試
public static void main(String[] args) {
JdbcUtil.getConnection();
}
}
輸出:
com.mysql.jdbc.Driver jdbc:mysql://localhost:3306/mail root root
這樣做,我們?cè)谙胍獡Q數(shù)據(jù)庫(kù)的時(shí)候只要把properties文件中的值更改了就可以,代碼是不需要修改的,因?yàn)閖dbc是固定的。在其他的配置方面也可以使用這種方法,提高了代碼的復(fù)用性
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java 各種數(shù)據(jù)類型的互相轉(zhuǎn)換實(shí)例代碼
這篇文章主要介紹了java 各種數(shù)據(jù)類型的互相轉(zhuǎn)換實(shí)例代碼,需要的朋友可以參考下2020-10-10
SpringBoot訪問(wèn)靜態(tài)資源的配置及順序說(shuō)明
這篇文章主要介紹了SpringBoot訪問(wèn)靜態(tài)資源的配置及順序說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
SpringBoot+Vue實(shí)現(xiàn)動(dòng)態(tài)菜單的思路梳理
這篇文章主要為大家詳細(xì)介紹了利用SpringBoot+Vue實(shí)現(xiàn)動(dòng)態(tài)菜單的思路梳理,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動(dòng)手嘗試一下2022-07-07
如何通過(guò)eclipse web項(xiàng)目導(dǎo)入itellij idea并啟動(dòng)
這篇文章主要介紹了如何通過(guò)eclipse web項(xiàng)目導(dǎo)入itellij idea并啟動(dòng),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12
詳解SpringMVC的攔截器鏈實(shí)現(xiàn)及攔截器鏈配置
攔截器(Interceptor)是一種動(dòng)態(tài)攔截方法調(diào)用的機(jī)制,在SpringMVC中動(dòng)態(tài)攔截控制器方法的執(zhí)行。本文將詳細(xì)講講SpringMVC中攔截器參數(shù)及攔截器鏈配置,感興趣的可以嘗試一下2022-08-08
Spring Boot應(yīng)用啟動(dòng)時(shí)自動(dòng)執(zhí)行代碼的五種方式(常見(jiàn)方法)
Spring Boot為開(kāi)發(fā)者提供了多種方式在應(yīng)用啟動(dòng)時(shí)執(zhí)行自定義代碼,這些方式包括注解、接口實(shí)現(xiàn)和事件監(jiān)聽(tīng)器,本文我們將探討一些常見(jiàn)的方法,以及如何利用它們?cè)趹?yīng)用啟動(dòng)時(shí)執(zhí)行初始化邏輯,感興趣的朋友一起看看吧2024-04-04
SpringBoot整合Lucene實(shí)現(xiàn)全文檢索的詳細(xì)步驟
全文搜索(Full-Text?Search)是指對(duì)大規(guī)模存儲(chǔ)在計(jì)算機(jī)系統(tǒng)中的文本數(shù)據(jù)進(jìn)行檢索和匹配的技術(shù),它允許用戶輸入關(guān)鍵字,然后從海量的文本數(shù)據(jù)中快速找到相關(guān)的信息,本文介紹了SpringBoot整合Lucene實(shí)現(xiàn)全文檢索的詳細(xì)步驟,需要的朋友可以參考下2024-03-03
IDEA設(shè)置字體隨鼠標(biāo)滾動(dòng)放大縮小的實(shí)現(xiàn)
這篇文章主要介紹了IDEA設(shè)置字體隨鼠標(biāo)滾動(dòng)放大縮小的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01

