Java之DriverManager簡單介紹
開心一笑
愛神和月老
甲:「你知道西方國家鬧離婚的為什麼比中國的多嗎?」
乙:「這還不簡單,因為西方的愛神丘比特是個娃娃,而丘比特是個娃娃,而丘比特是娃娃中國的是月下老人,經驗當然豐富許多! ”
提出問題
DriverManager類的簡單學習? ? ?
解決問題
DriverManager在java.sql這個包裡面,管理一組JDBC 驅動程式的基本服務
[code]package com.evada.de; import java.sql.Connection; import java.sql.Driver; import java.sql.DriverManager; import java.util.Enumeration; /** * 用静态工厂方法管理一个唯一的可重用的连接 * Created by Ay on 2016/5/1. */ public class ConnUtils{ private ConnUtils(){} private static Connection con; //在静态代码块中创建与数据库的连接 static{ try{ //postgresql驱动名称 Class.forName("org.postgresql.Driver"); //数据库连接路径 String url = "jdbc:postgresql://127.0.0.1:5432/postgres"; //用户名和密码 con = DriverManager.getConnection(url, "postgres", "888888"); }catch(Exception e){ throw new RuntimeException(e.getMessage(),e); } } //使用一个静态方法-静态工厂方法,返回connection实例 public static Connection getCon(){ return con; } //main函数测试用 public static void main(String[] args) { //获取所有的数据库驱动 Enumeration<Driver> driverEnum = DriverManager.getDrivers(); //打印出所有驱动信息 while(driverEnum.hasMoreElements()){ System.out.println(driverEnum.nextElement()); } } }
運行結果:
[code]org.mariadb.jdbc.Driver@7cef4e59 com.alibaba.druid.proxy.DruidDriver@3ada9e37 com.alibaba.druid.mock.MockDriver@4ec6a292 org.postgresql.Driver@71c7db30
解釋,因為我們的專案包裡有如下圖片的資料庫驅動,所以會列印下面資訊
這兩者的區別:
DriverManager.registerDriver(new Driver()); Class.forName(“com.mysql.jdbc.Driver”);
org.postgresql.Driver類源碼說在連接數據庫是只new了一個Driver
[code]static { sharedTimer = new SharedTimer(logger); try { //注册 register(); } catch (SQLException var1) { throw new ExceptionInInitializerError(var1); } protocols = new String[]{"jdbc", "postgresql"}; } public static void register() throws SQLException { if(isRegistered()) { throw new IllegalStateException("Driver is already registered......); } else { Driver registeredDriver = new Driver(); DriverManager.registerDriver(registeredDriver); registeredDriver = registeredDriver; } }
再來看看DriverManager的源碼,它會把Driver包裝到DriverInfo中,
[code]// public static synchronized void registerDriver(java.sql.Driver driver, DriverAction da) throws SQLException { /* Register the driver if it has not already been added to our list */ if(driver != null) { //将驱动包装到DriverInfo中 registeredDrivers.addIfAbsent(new DriverInfo(driver, da)); } else { // This is for compatibility with the original DriverManager throw new NullPointerException(); } println("registerDriver: " + driver); }
Class.forName(“com.mysql.jdbc.Driver”);
結論:DriverManager.registerDriver(new Driver()); 多new一個Driver浪費;而Class.forName(“com.mysql.jdbc.Driver”); 單例形式,更推薦…
以上就是Java之DriverManager簡單介紹的內容,更多相關內容請關注PHP中文網(www.php.cn)!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

Java是熱門程式語言,適合初學者和經驗豐富的開發者學習。本教學從基礎概念出發,逐步深入解說進階主題。安裝Java開發工具包後,可透過建立簡單的「Hello,World!」程式來實踐程式設計。理解程式碼後,使用命令提示字元編譯並執行程序,控制台上將輸出「Hello,World!」。學習Java開啟了程式設計之旅,隨著掌握程度加深,可創建更複雜的應用程式。
