摘要:我們定義好一個(gè)配置文件,讓程序來讀取這個(gè)文件,這個(gè)程序是固定的,只是配置文件我們自己來寫,這樣做的好處就是,我們?cè)诟臄?shù)據(jù)庫的時(shí)候,不需要更改代碼,提高了代碼的復(fù)用性。下圖是連接時(shí)候需要的信息我的數(shù)據(jù)庫是,和都是,讀者根據(jù)自己的數(shù)據(jù)庫來寫。
之前我們?cè)谌腴Tjdbc的時(shí)候,常用這種方法連接數(shù)據(jù)庫:
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ù)庫,代碼簡單易懂。同時(shí)也帶來了一個(gè)最重要的問題,當(dāng)有一天我們想要換數(shù)據(jù)庫的時(shí)候,怎么辦?驅(qū)動(dòng)也變了,什么都變了,你可以說改代碼啊,程序就是方便我們的,處理事情的方式越簡單越好,這樣更改代碼的方式很low啊,也許我們只是改了四行代碼。代碼的復(fù)用性我們可能都沒有實(shí)現(xiàn)。
我們定義好一個(gè)配置文件,讓程序來讀取這個(gè)文件,這個(gè)程序是固定的,只是配置文件我們自己來寫,這樣做的好處就是,我
們?cè)诟臄?shù)據(jù)庫的時(shí)候,不需要更改代碼,提高了代碼的復(fù)用性。
先介紹一下propertie文件: Java中的properties文件是一種配置文件,主要用于表達(dá)配置信息,文件類型為*.properties,格式為文本文件,文件的內(nèi)容是格式是 "鍵=值"的格式。
可以理解為Map結(jié)構(gòu),鍵值對(duì)的方式存儲(chǔ),可以根據(jù)鍵來找到值。下圖是java連接mysql時(shí)候需要的信息(我的數(shù)據(jù)庫是mail,username和password都是root,讀者根據(jù)自己的數(shù)據(jù)庫來寫)。一個(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ù)庫連接 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ù)庫的時(shí)候只要把properties文件中的值更改了就可以,代碼是不需要修改的,因?yàn)閖dbc是固定的。在其他的配置方面也可以使用這種方法,提高了代碼的復(fù)用性
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/74108.html
摘要:是訪問數(shù)據(jù)庫的標(biāo)準(zhǔn)規(guī)范提供了一種基準(zhǔn)據(jù)此可以構(gòu)建更高級(jí)的工具和接口,使數(shù)據(jù)庫開發(fā)人員能夠編寫數(shù)據(jù)庫應(yīng)用程序。在將此值發(fā)送到數(shù)據(jù)庫時(shí),驅(qū)動(dòng)程序?qū)⑺D(zhuǎn)換成一個(gè)類型值。 1.JDBC概念和數(shù)據(jù)庫驅(qū)動(dòng)程序 A: JDBC概述 JDBC(Java Data Base Connectivity,java數(shù)據(jù)庫連接)是一種用于執(zhí)行SQL語句的Java API,可以為多種關(guān)系數(shù)據(jù)庫提供統(tǒng)一訪問,...
摘要:是訪問數(shù)據(jù)庫的標(biāo)準(zhǔn)規(guī)范提供了一種基準(zhǔn)據(jù)此可以構(gòu)建更高級(jí)的工具和接口,使數(shù)據(jù)庫開發(fā)人員能夠編寫數(shù)據(jù)庫應(yīng)用程序。在將此值發(fā)送到數(shù)據(jù)庫時(shí),驅(qū)動(dòng)程序?qū)⑺D(zhuǎn)換成一個(gè)類型值。例如值不支持中文,如果需要使用非英文字符,將進(jìn)行轉(zhuǎn)換。 01JDBC概念和數(shù)據(jù)庫驅(qū)動(dòng)程序 * A: JDBC概念和數(shù)據(jù)庫驅(qū)動(dòng)程序 * a: JDBC概述 * JDBC(Java Data...
摘要:一配置屬性詳解可以在各式各樣不同環(huán)境下工作而設(shè)計(jì)的因此存在著大量的配置參數(shù)。以簡便操作,多數(shù)配置參數(shù)都有默認(rèn)的配置值也是我們?nèi)粘J褂玫谋仨毱贰? Hibernate (開放源代碼的對(duì)象關(guān)系映射框架) Hibernate是一個(gè)開放源代碼的對(duì)象關(guān)系映射框架,它對(duì)JDBC進(jìn)行了非常輕量級(jí)的對(duì)象封裝, 它將POJO與數(shù)據(jù)庫表建立映射關(guān)系,是一個(gè)全自動(dòng)的orm框架,hibernat...
閱讀 2181·2021-11-11 16:55
閱讀 3246·2021-10-11 10:58
閱讀 3203·2021-09-13 10:28
閱讀 4130·2021-07-26 23:57
閱讀 1138·2019-08-30 15:56
閱讀 1401·2019-08-29 13:15
閱讀 1333·2019-08-26 18:18
閱讀 1357·2019-08-26 13:44