<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    konhon

    忘掉過去,展望未來。找回自我,超越自我。
    逃避不一定躲的過, 面對不一定最難過, 孤單不一定不快樂, 得到不一定能長久, 失去不一定不再擁有, 可能因為某個理由而傷心難過, 但我卻能找個理由讓自己快樂.

    Google

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      203 Posts :: 0 Stories :: 61 Comments :: 0 Trackbacks
    全面解析JDBC(三)
    作者:未知?? ??文章來源:www.jspcn.net
    訪問次數: 次????加入時間:2005-01-19
    JDBC驅動管理內幕是怎么樣的?

      DriverManager 類是 JDBC 的管理層,作用于用戶和驅動程序之間。它跟蹤可用的驅動程序,并在數據庫和相應驅動程序之間建立連接。另外,DriverManager類也處理諸如驅動程序登錄時間限制及登錄和跟蹤消息的顯示等事務。

      對于簡單的應用程序,一般程序員需要在此類中直接使用的唯一方法是DriverManager.getConnection。正如名稱所示,該方法將建立與數據庫的連接。JDBC允許用戶調用DriverManager的方法getDriver、getDrivers和registerDriver及Driver的方法connect。但多數情況下,讓DriverManager類管理建立連接的細節為上策。

      1. 跟蹤可用驅動程序

      DriverManager類包含一列Driver類,它們已通過調用方法DriverManager.registerDriver對自己進行了注冊。所有Driver類都必須包含有一個靜態部分。它創建該類的實例,然后在加載該實例時DriverManager類進行注冊。這樣,用戶正常情況下將不會直接調用DriverManager.registerDriver;而是在加載驅動程序時由驅動程序自動調用。加載Driver類,然后自動在DriverManager中注冊的方式有兩種:

      (1)調用方法Class.forName

      這將顯式地加載驅動程序類。由于這與外部設置無關,因此推薦使用這種加載驅動程序的方法。以下代碼加載類acme.db.Driver:Class.forName("acme.db.Driver")。

      如果將acme.db.Driver編寫為加載時創建實例,并調用以該實例為參數的DriverManager.registerDriver(本該如此),則它在DriverManager的驅動程序列表中,并可用于創建連接。

      (2)將驅動程序添加到Java.lang.System的屬性jdbc.drivers中

      這是一個由DriverManager類加載的驅動程序類名的列表,由冒號分隔:初始化DriverManager類時,它搜索系統屬性jdbc.drivers,如果用戶已輸入了一個或多個驅動程序,則DriverManager類將試圖加載它們。以下代碼說明程序員如何在~/.hotJava/properties中輸入三個驅動程序類(啟動時,HotJava將把它加載到系統屬性列表中):

      jdbc.drivers=foo.bah.Driver:wombat.sql.Driver:bad.test.ourDriver;

      對DriverManager方法的第一次調用將自動加載這些驅動程序類。注意:加載驅動程序的第二種方法需要持久的預設環境。如果對這一點不能保證,則調用方法Class.forName顯式地加載每個驅動程序就顯得更為安全。這也是引入特定驅動程序的方法,因為一旦DriverManager類被初始化,它將不再檢查jdbc.drivers屬性列表。

      在以上兩種情況中,新加載的Driver類都要通過調用DriverManager.registerDriver類進行自我注冊。如上所述,加載類時將自動執行這一過程。

      由于安全方面的原因,JDBC管理層將跟蹤哪個類加載器提供哪個驅動程序。這樣,當DriverManager類打開連接時,它僅使用本地文件系統或與發出連接請求的代碼相同的類加載器提供的驅動程序。

      2. 建立連接

      加載Driver類并在DriverManager類中注冊后,它們即可用來與數據庫建立連接。當調用DriverManager.getConnection方法發出連接請求時,DriverManager將檢查每個驅動程序,查看它是否可以建立連接。

      有時可能有多個JDBC驅動程序可以與給定的URL連接。例如,與給定遠程數據庫連接時,可以使用JDBC-ODBC橋驅動程序、JDBC到通用網絡協議驅動程序或數據庫廠商提供的驅動程序。在這種情況下測試驅動程序的順序至關重要,因為DriverManager將使用它所找到的第一個可以成功連接到給定URL的驅動程序。

      首先DriverManager試圖按注冊的順序使用每個驅動程序(jdbc.drivers中列出的驅動程序總是先注冊)。它將跳過代碼不可信任的驅動程序,除非加載它們的源與試圖打開連接的代碼的源相同。它通過輪流在每個驅動程序上調用方法Driver.connect,并向它們傳遞用戶開始傳遞給方法DriverManager.getConnection的URL來對驅動程序進行測試,然后連接第一個認出該URL的驅動程序。這種方法初看起來效率不高,但由于不可能同時加載數十個驅動程序,因此每次連接實際只需幾個過程調用和字符串比較。

      以下代碼是通常情況下用驅動程序(例如JDBC-ODBC橋驅動程序)建立連接所需所有步驟的示例:



    Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");//加載驅動程序
    String url = "jdbc:odbc:fred";
    DriverManager.getConnection(url,"userID","passwd");
    posted on 2006-03-22 20:45 konhon 優華 閱讀(382) 評論(0)  編輯  收藏 所屬分類: Java
    主站蜘蛛池模板: 国产精品亚洲综合一区| 亚洲香蕉免费有线视频| 日日夜夜精品免费视频| 亚洲乱理伦片在线观看中字| 亚洲成在人线aⅴ免费毛片| 亚洲xxxxxx| 天天拍拍天天爽免费视频| 亚洲国产成人AV网站| 亚洲av午夜成人片精品电影 | 免费在线观看污网站| 日本一区二区三区在线视频观看免费| 日韩亚洲国产综合久久久| 97视频免费观看2区| 亚洲AV成人片色在线观看高潮| 三年片在线观看免费大全电影| 亚洲在成人网在线看| 欧美大尺寸SUV免费| 国产亚洲日韩在线a不卡| 亚洲一区日韩高清中文字幕亚洲 | 亚洲AV成人片无码网站| 久久久久一级精品亚洲国产成人综合AV区| rh男男车车的车车免费网站| 亚洲av日韩av不卡在线观看 | 中文字幕在线免费| 久久亚洲精品专区蓝色区| 国产精品美女自在线观看免费| 女人裸身j部免费视频无遮挡| 亚洲AV成人一区二区三区AV| 国产无人区码卡二卡三卡免费| 精品久久久久久亚洲中文字幕| 中文字幕亚洲一区| 黄网站色在线视频免费观看| 成a人片亚洲日本久久| 亚洲精品国产精品乱码视色| 九九精品免费视频| 一级做a免费视频观看网站| 久久亚洲精精品中文字幕| 国产免费人成在线视频| 少妇太爽了在线观看免费视频| 亚洲熟妇丰满xxxxx| 亚洲第一极品精品无码久久|