java 加載數據庫驅動


JDBC編程步驟見 JDBC編程步驟

 

 

JDBC編程的第一步是加載數據庫驅動,使用Class類的forName()方法,Class.forName("com.mysql.jdbc.Driver")。

        // 加載MySQL驅動
        Class.forName("com.mysql.jdbc.Driver");

        // 獲取數據庫連接
        Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/crashcourse", "root", "123456");

 

比較令人疑惑的是,它是如何加載驅動的,后續的DriverManager又是如何利用該驅動的。

 

打開Driver源碼,可以看到如下的內容

 

/**
 * 
 * <p>
 * When a Driver class is loaded, it should create an instance of itself and register it with the DriverManager. 
* This means that a user can load and register a * driver by doing Class.forName("foo.bah.Driver")
*/

 

源碼中的靜態代碼塊:

    static {
        try {
            java.sql.DriverManager.registerDriver(new Driver());
        } catch (SQLException E) {
            throw new RuntimeException("Can't register driver!");
        }
    }

 

由此可知,Class.forName("com.mysql.jdbc.Driver"),加載Driver類且靜態初始化該類時,會創建Driver對象,並由DriverManager進行register。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2026 CODEPRJ.COM