『壹』 資料庫驅動為什麼要使用Class.forName()
在Java開發特別是資料庫開發中,經常會用到Class.forName( )這個方法。通過查詢Java Documentation我們會發現使用Class.forName( )靜態方法的目的是為了動態載入類。在載入完成後,一般還要調用Class下的newInstance( )靜態方法來實例化對象以便操作。因此,單單使用Class.forName( )是動態載入類是沒有用的,其最終目的是為了實例化對象。
Class.forName("")返回的是類
Class.forName("").newInstance()返回的是object
剛才提到,Class.forName("");的作用是要求JVM查找並載入指定的類,如果在類中有靜態初始化器的話,JVM必然會執行該類的靜態代碼 段。而在JDBC規范中明確要求這個Driver類必須向DriverManager注冊自己,即任何一個JDBC Driver的 Driver類的代碼都必須類似如下:
public class MyJDBCDriver implements Driver {static {DriverManager.registerDriver(new MyJDBCDriver());}}既然在靜態初始化器的中已經進行了注冊,所以我們在使用JDBC時只需要Class.forName(XXX.XXX);就可以了。
we just want to load the driver to jvm only, but not need to user the instance of driver, so call Class.forName(xxx.xx.xx) is enough, if you call Class.forName(xxx.xx.xx).newInstance(), the result will same as calling Class.forName(xxx.xx.xx), because Class.forName(xxx.xx.xx).newInstance() will load driver first, and then create instance, but the instacne you will never use in usual, so you need not to create it.總結:jdbc資料庫驅動程序最終的目的,是為了程序員能拿到資料庫連接,而進行jdbc規范的資料庫操作。拿到連接的過程是不需要你自己來實例化驅動程序的,而是通過 DriverManger.getConnection(string str); 。因此一般情況下,對於程序員來說,除非特別需求,是不會自己去實例化一個資料庫驅動使用裡面的方法的。
『貳』 Class.forName
不同的資料庫裡面的寫法是不一樣的,如果用的是sqlserve資料庫的話 :
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver")//載入資料庫驅動
conn = DriverManager.getConnection("jdbc:sqlserver://localhost:1433;DataBaseName=資料庫名","用戶名","密碼") //建立資料庫連接
『叄』 java中奇怪的問題;為啥在連接資料庫的時候不用Class.forName()方法也可以連上資料庫求各位大俠幫我
那句話的作用是載入驅動,沒有驅動是運行不起來,也就連接不到資料庫,報錯:沒有找到合適的驅動。你那句一定要寫的應該是告訴電腦是載入什麼驅動。向我這個就是寫明是SQLServerDriver驅動
『肆』 java中class.forname是什麼類
Class是一個類,表示對所有java類進行的一個抽象。可以看jdk說明如下:
forName(String classname)是它的一個靜態方法,可以通過className返回一個類對象。比如資料庫連接中常用這句代碼:
Class driver=Class.forName("jdbc.mysql.jdbc.driver");
參數是驅動類的名字,這句代碼表示通過jdbc包返回一個驅動類對象!
『伍』 關於Class.forName("com.mysql.jdbc.Driver");出錯
你好,很高興回答你的問題。建議檢查一下包有沒有正常引入,如果引入了再檢查一下引用的包中的Driver是不是在com.mysql.jdbc這個包下。
『陸』 如何在構造方法中使用Class.forName()[關於資料庫的使用]
這個錯誤和使用構造沒關系的
是沒有載入到相關的類
把驅動的類庫添加到 路徑中
『柒』 Class.forName()問題
這個是連接資料庫的時候載入資料庫驅動的方法吧,demo要換成相應的資料庫驅動
『捌』 Java載入資料庫連接驅動為什麼要用Class.forName()方法
靜態初始化過程解釋起來太麻煩,希望你自己去閱讀一下Thinking in Java 2nd 的第5-8章
不過,我可以給你解釋一下為什麼在調用JDBC的時候,我們總要寫這句話:
JDBC提供的DriverManager類用於跟蹤所有可用的JDBC驅動,並在用戶需要時選擇合適的驅動提供給用戶
但是其跟蹤不是自動的,必須由可用的JDBC驅動的Driver類自己在DriverManager上進行注冊
但是這個注冊過程一般是由Driver類載入的時候自動完成的
Class.forName("org.postgresql.driver");
這句就是為了載入這個類進入內存用的
而在一個類載入入內存的時候,類中的靜態初始化過程會執行,關於這部分就需要你去Thinking in Java里去看了
而剛才所說的Driver類在DriverManager上注冊的過程,事實上就是在這個靜態初始化塊中完成的
也就是說Class.forName("org.postgresql.driver");這句話在這里的用處就是
強制JVM將org.postgresql.Driver這個類載入入內存,以便將其注冊到DriverManager類上去
『玖』 java中連接資料庫,要用class.forname()載入driver類,這里的driver類是驅動器程序類嗎
Driver是一個介面,每個驅動器程序會提供一個實現了Driver介面的類,當使用Class.forName()
的時候實現了Driver介面的類會創建自己的實例,並向DriverManager注冊該實例。
『拾』 使用jdbc連接資料庫時,為什麼要先使用Class.forName(String name)載入類
是為了聲明當前用的是哪個資料庫驅動,以及將驅動注冊到驅動管理器裡面以sqlserver為例
你除了可以用Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance()來實現對資料庫驅動的聲明,你還可以用DriverManager.registerDriver(new com.microsoft.jdbc.sqlserver.SQLServerDriver());來實現同樣的效果
你可以反編譯SQLServerDriver.class來看一下,他在被實例化的時候會調用BaseDriver.registerDriver(new SQLServerDriver());方法,來將自己注冊到驅動管理器 裡面
然後你取得資料庫連接的時候不是需要調用DriverManager.getConnection(url,username,password);方法么,只有注冊了驅動,系統才知道你連接的是什麼資料庫,用哪個驅動程序.