JDBC獲取數(shù)據(jù)庫連接由淺入深
添加MySQL驅(qū)動:
不同的數(shù)據(jù)庫廠商都會有自己的實現(xiàn)java.sql.Driver接口的驅(qū)動程序,例如mysql的實現(xiàn)就是com.mysql.jdbc.Driver,將mysql-connector-java-版本號-bin.jar添加到相應(yīng)工程的目錄(如果是動態(tài)web項目的話,需要將對應(yīng)的jar包放到WebRoot目錄下)下面,右鍵選擇add as library就完成了(如果是使用的eclipse,則是點擊build path)。
在mysql8.0之后驅(qū)動程序的全路徑應(yīng)該是com.mysql.cj.jdbc.Driver,使用原來的路徑也可以正確運(yùn)行,只是運(yùn)行時會在終端輸出一段推薦使用新路徑的紅色文字
獲取連接:
Driver
獲取連接之前。首先需要創(chuàng)建驅(qū)動類的對象,通過驅(qū)動類的connect()方法即可獲取數(shù)據(jù)庫連接。connect()方法的參數(shù)如下所示:
Connection connect(String url, java.util.Properties info)
其中url是用來標(biāo)識一個驅(qū)動程序,而驅(qū)動程序管理器就是通過url來選擇正確的驅(qū)動程序。url的格式為:jdbc:子協(xié)議:子名稱。
jdbc是JDBC url中的協(xié)議,而且在JDBC中協(xié)議恒為jdbc
子協(xié)議:用于標(biāo)識一個數(shù)據(jù)庫驅(qū)動程序,MySQL就是mysql。
子名稱:同來標(biāo)識數(shù)據(jù)庫,格式為 主機(jī)名:端口號/數(shù)據(jù)庫名
例:jdbc:mysql://localhost:3306/databasename
Properties類型的info則是用來提供數(shù)據(jù)庫的用戶名(user)和密碼(password)
綜上所述,我們可以將獲取連接分為四步,分別是:
實例化Driver類
提供url
通過Properties提供用戶名和密碼
調(diào)用Driver類的connect()方法獲取連接
具體實現(xiàn)代碼為:
@Test
public void testConnection(){
try {
//提供驅(qū)動接口類的實現(xiàn)對象
Driver driver = null;
driver = new com.mysql.cj.jdbc.Driver();
//url,指明具體要操作的數(shù)據(jù)
String url = "jdbc:mysql://localhost:3306/test";
//指明用戶名和密碼
Properties pros = new Properties();
pros.setProperty("user", "root");
pros.setProperty("password", "root");
//通過Driver中的connect()方法獲取連接
Connection connect = driver.connect(url, pros);
System.out.println(connect);
} catch (SQLException e) {
e.printStackTrace();
}
}
使用以上的代碼有一個缺點就是在代碼中使用了第三方的API,我們可以通過反射的方式來創(chuàng)建驅(qū)動類的對象,改進(jìn)后的代碼為:
@Test
public void testConnection(){
try {
//實例化Driver
String className = "com.mysql.cj.jdbc.Driver";
Class cls = Class.forName(className);
Driver driver = (Driver)cls.newInstance();
//url,指明具體要操作的數(shù)據(jù)
String url = "jdbc:mysql://localhost:3306/test";
//指明用戶名和密碼
Properties pros = new Properties();
pros.setProperty("user", "root");
pros.setProperty("password", "root");
//通過Driver中的connect()方法獲取連接
Connection connect = driver.connect(url, pros);
System.out.println(connect);
} catch (SQLException e) {
e.printStackTrace();
}
}
DriverManager
通過DriverManager的getConnection()方法來獲取連接,首先看一下該方法的參數(shù)詳情:
public static Connection getConnection(String url,String user, String password)
通過該方法的三個參數(shù)再加上驅(qū)動的具體路徑,我們可以得知通過這種方法獲取數(shù)據(jù)庫連接的四個要素分別為:
url
用戶名
密碼
驅(qū)動路徑
所以現(xiàn)在獲取連接的步驟應(yīng)該為:
給明獲取數(shù)據(jù)庫連接的四要素
實例化Driver
注冊驅(qū)動
獲取連接
具體代碼為:
@Test
public void testConnection(){
try {
//給出數(shù)據(jù)庫連接的四個基本要素
String url = "jdbc:mysql://127.0.0.1:3306/test";
String driverName = "com.mysql.cj.jdbc.Driver";
String user = "root";
String password = "root";
//實例化Driver
Class cls = Class.forName(driverName);
Driver driver = (Driver)cls.newInstance();
//注冊驅(qū)動
DriverManager.registerDriver(driver);
//獲取連接
Connection connection = DriverManager.getConnection(url, user, password);
System.out.println(connection);
} catch (Exception e) {
e.printStackTrace();
}
}
但是以上的方式任然可以簡化,我們先來看com.mysql.cj.jdbc.Driver的具體實現(xiàn):
public class Driver extends NonRegisteringDriver implements java.sql.Driver {
public Driver() throws SQLException {
}
static {
try {
DriverManager.registerDriver(new Driver());
} catch (SQLException var1) {
throw new RuntimeException("Can't register driver!");
}
}
}
可以看到在Driver類中有一個靜態(tài)代碼塊中有注冊驅(qū)動的那一步,所以在實例化Driver類的時候同時就將驅(qū)動注冊了,所以以上代碼中注冊驅(qū)動的代碼可以刪掉。
通過配置文件配合DriverManager獲取連接
我們可以將獲取數(shù)據(jù)庫連接的四大要素寫在配置文件中,首先創(chuàng)建配置文件jdbc.properties,其中內(nèi)容為:
user=root password=root url=jdbc:mysql://localhost:3306/test driverName=com.mysql.cj.jdbc.Driver
通過讀取配置文件中的信息獲得四要素,從而獲取連接,最終版的代碼為:
@Test
public void testConnection5(){
try {
//加載配置文件
//最終版配合配置文件使用
Properties pros = new Properties();
InputStream is = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
pros.load(is);
//讀取配置信息
String user = pros.getProperty("user");
String password = pros.getProperty("password");
String url = pros.getProperty("url");
String driverName = pros.getProperty("driverName");
//加載驅(qū)動
Class.forName(driverName);
//獲取連接
Connection connection = DriverManager.getConnection(url, user, password);
System.out.println(connection);
} catch (Exception e) {
e.printStackTrace();
}
}
通過這種方式獲取數(shù)據(jù)庫的連接時,如果需要修改用戶名密碼,驅(qū)動類或者操作的數(shù)據(jù)庫時就不再需要修改代碼,只需要修改配置文件中的各項的值即可實現(xiàn)更改。
到此這篇關(guān)于JDBC獲取數(shù)據(jù)庫連接由淺入深的文章就介紹到這了,更多相關(guān)JDBC獲取數(shù)據(jù)庫連接內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java查找不重復(fù)無序數(shù)組中是否存在兩個數(shù)字的和為某個值
今天小編就為大家分享一篇關(guān)于Java查找不重復(fù)無序數(shù)組中是否存在兩個數(shù)字的和為某個值,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01
淺談spring中用到的設(shè)計模式及應(yīng)用場景
下面小編就為大家?guī)硪黄獪\談spring中用到的設(shè)計模式及應(yīng)用場景。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
解決@CachePut設(shè)置的key值無法與@CacheValue的值匹配問題
這篇文章主要介紹了解決@CachePut設(shè)置的key的值無法與@CacheValue的值匹配問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
IDEA+Maven搭建Spring環(huán)境的詳細(xì)教程
這篇文章主要介紹了IDEA+Maven搭建Spring環(huán)境的詳細(xì)教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11

