標籤:class www. 資料庫連接 rman 取資料 lin gis with ash
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。
mark
java 載入資料庫驅動