




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、JDBC 基本概念與應(yīng)用楊頌講課內(nèi)容nJDBC基本概念n如何通過JDBC訪問數(shù)據(jù)庫JDBC基本概念nJDBC為java開發(fā)者使用數(shù)據(jù)庫提供了統(tǒng)一的編程接口,它由一組java類和接口組成。是java程序與數(shù)據(jù)庫系統(tǒng)通信的標準API。JDBC API 使得開發(fā)人員可以使用純java的方式來連接數(shù)據(jù)庫,并執(zhí)行操作。JDBC的結(jié)構(gòu)n程序包n主要的類nJdbc的幾種類型JDBC的兩個程序包nJava.sql(核心API)nJavax.sql (擴展API) nJdbc網(wǎng)站:http:/ (擴展API) n它主要為數(shù)據(jù)庫方面的高級操作提供了接口和類。如連接管理、分布式事務(wù)和行集等。JDBC常用接口nDri
2、ver接口nDriverManager接口nConnection接口接口nStatement接口nResult接口Driver接口nDriver接口由數(shù)據(jù)庫廠家提供,對于java開發(fā)者而言,只需要使用Driver接口就可以了。n在編程中要連接數(shù)據(jù)庫,必須先裝載特定廠商的數(shù)據(jù)庫驅(qū)動程序。不同的數(shù)據(jù)庫有不同的裝載方法。裝載驅(qū)動n裝載JDBC-ODBC驅(qū)動:Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”);n裝載MS SQL Server驅(qū)動:Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDrive
3、r”);裝載驅(qū)動n裝載MySql驅(qū)動Class.forName(“org.gjt.mm.mysql.Driver”);n裝載Oracle驅(qū)動Class.forName(“oracle.jdbc.driver.OracleDriver”);DriverManager接口nDriverManager是JDBC的管理層,作用于用戶和驅(qū)動程序之間。nDriverManager跟蹤可用的驅(qū)動程序,并在數(shù)據(jù)庫和相應(yīng)的驅(qū)動程序之間建立連接。nDriverManager處理驅(qū)動程序登陸時間限制、跟蹤消息的顯示等。Connection接口nConnection與特定數(shù)據(jù)庫的連接(會話),在連接上下文中執(zhí)行 SQ
4、L 語句并返回結(jié)果。nDriverManager的getConnection()方法建立在JDBC URL中定義的數(shù)據(jù)庫Connection連接上: Connection con= DriverManager.getConnection(url,login,password);Statement接口n用于執(zhí)行靜態(tài) SQL 語句并返回它所生成結(jié)果的對象。n一般情況下使用connection.createStatement()方法可以得到Statement實例。Statement接口n三種Statement對象: Statement、PreparedStatement和CallableStatem
5、ent。n常用的Statement方法: execute():運行語句,返回是否有結(jié)果集。 executeQuerty():運行查詢語句,返回ResultSet結(jié)果集。 executeUpdate():運行更新操作,返回更新的行數(shù)。ResultSet接口nStatement執(zhí)行SQL語句時返回ResultSet結(jié)果集。nResultSet提供的檢索不同類型字段的方法,常用的有: getString():獲得在數(shù)據(jù)庫里是varchar、char等數(shù)據(jù)類型的對象。 getFloar():獲得雜數(shù)據(jù)庫里是Float類型的對象。ResultSet接口ngetDate():獲得在數(shù)據(jù)庫里面是Date類型
6、的數(shù)據(jù)。ngetBoolean():獲得在數(shù)據(jù)庫里面是Boolean類型的數(shù)據(jù)。ngetObject():在Sql中無對應(yīng)類型,獲得序列化對象。JDBC的幾種類型n數(shù)據(jù)庫廠商一般會提供一組API訪問數(shù)據(jù)庫。流行的數(shù)據(jù)庫如Oracle、SQL Server、Sybase、Informix都提供了專用的API。JDBC的幾種類型nType 1 JDBC-ODBC橋nType 2 部分java部分本機驅(qū)動程序nType 3 中間數(shù)據(jù)訪問服務(wù)器nType 4 純java驅(qū)動程序Type 1 JDBC-ODBC橋nJDBC Type 1 驅(qū)動程序基于 JDBC-ODBC 橋。它是把JDBC操作翻譯成對于
7、的ODBC調(diào)用。n優(yōu)點:可以訪問所有ODBC可以訪問的數(shù)據(jù)庫。n缺點:執(zhí)行效率低。Type 1 JDBC-ODBC橋Type 2 部分java部分本機驅(qū)動程序nJDBC Type 2 驅(qū)動程序依靠特定于操作系統(tǒng)的庫(共享庫)來與 RDBMS 通信。應(yīng)用程序?qū)⒀b入這種 JDBC 驅(qū)動程序,而驅(qū)動程序?qū)⑹褂霉蚕韼靵砼c 數(shù)據(jù)庫 服務(wù)器通信。Type 2 部分java部分本機驅(qū)動程序Type 3 中間數(shù)據(jù)訪問服務(wù)器nJDBC Type 3 驅(qū)動程序?qū)?yīng)用程序與中間件服務(wù)器連接,中間件服務(wù)器將應(yīng)用程序的JDBC調(diào)用映射到適當?shù)臄?shù)據(jù)庫驅(qū)動程序上。nWebLogic的驅(qū)動池就是屬于type3類型。Type
8、3 中間數(shù)據(jù)訪問服務(wù)器Type 4 純java驅(qū)動程序nType 4 驅(qū)動程序是僅用于 Java 的 JDBC 驅(qū)動程序,它直接連接到數(shù)據(jù)庫服務(wù)器。Type 4 純java驅(qū)動程序JDBC object, interface modelDriver ManagerDriverResultSetConnectionStatementPreparedStatementCallableStatementRegisterProvideExecuteResultExtendsExtendsJDBC的使用n程序?qū)懽鞑襟En使用實例JDBC 之程序?qū)懽鞑襟E1.注冊并載入特定的 Database DriverC
9、lass.forName(“sun.jdbc.odbc.JdbcOdbcDriver”);2.利用 Driver Manager 建立DB ConnectionConnection conn = DriverManager.getConnection(“jdbc:odbc:myDB”, “user”,”pw”);3.利用 Connection對象執(zhí)行 SQL 語句并返回它所生成結(jié)果的對象。 Statement stmt = conn.createStatement( );JDBC 之程序?qū)懽鞑襟E4.利用 Statement 執(zhí)行 SQL Statement必要時取得 ResultSet ref
10、erenceResultSets rs = stmt.executeQuery(“Select * from Book”);5.利用 ResultSet 讀取相關(guān)資料rs.getXXX(“fieldName”);6.依序關(guān)閉使用之對象及連接;ResultSet Statement Connection實例一 jdbc-odbc橋方式連接Access連接數(shù)據(jù)庫JDBC-ODBC連接數(shù)據(jù)庫 Connection con = null; try /調(diào)用JDBC-ODBC 驅(qū)動程序 Class.forName(sun.jdbc.odbc.JdbcOdbcDriver); /建立連接 con = Dri
11、verManager.getConnection(jdbc:odbc:MS Access Database;DBQ=.databaseCompany.mdb); Statement stmt = con.createStatement(); 連接數(shù)據(jù)庫JDBC-ODBC/利用 Statement 執(zhí)行 SQL Statement 并保存到ResultSet 中。ResultSet rst = stmt.executeQuery(SELECT chCompanyName FROM Company;);/處理結(jié)果集 while (rst.next() System.out.println(rst.
12、getString(chCompanyName); catch (Exception e) e.printStackTrace(); 不同數(shù)據(jù)庫廠商的JDBC驅(qū)動的使用nMicrosoft Access DatabasenMicrosoft SQL ServernMySQL DatabasenOracle DatabasenSybase DatabaseMicrosoft Access Database語法:/調(diào)用JDBC-ODBC 驅(qū)動程序Class.forName(sun.jdbc.odbc.JdbcOdbcDriver);/建立連接con = DriverManager.getConne
13、ction(jdbc:odbc:MS Access Database;DBQ=.databaseCompany.mdb);Microsoft SQL Server語法:Class.forName(net.sourceforge.jtds.jdbc.Driver );Connection con = DriverManager.getConnection(jdbc:jtds:sqlserver:/host:port/database,user,password);orConnection con = DriverManager.getConnection(jdbc:jtds:sybase:/host:port/database,user,password);MySQL Database語法:Class.forName(com.mysql.jdbc.Driver);Connection con = DriverManager.getConnection(jdbc:mysql:/host:port/database,user,password);Oracle Database語法:Class.forName(oracle.jdbc.driver.OracleDriver);Connection con = DriverManager.getConnec
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 第八章 第一節(jié) 自然特征與農(nóng)業(yè) 教學設(shè)計 -2023-2024學年人教版地理八年級下冊
- 2025屆河南省信陽市高三上學期第二次質(zhì)量檢測生物試題及答案
- 二零二五年度酒店集團食堂承包合同
- 2025年度清潔能源項目股東權(quán)益轉(zhuǎn)讓與投資合作協(xié)議
- 2025年度醫(yī)療健康產(chǎn)業(yè)園區(qū)醫(yī)生聘用合同
- 2025年度雙方離婚協(xié)議書范本及財產(chǎn)分割子女監(jiān)護及撫養(yǎng)
- 2025年度健康醫(yī)療行業(yè)雇工合同
- 2025年衡陽幼兒師范高等??茖W校單招職業(yè)適應(yīng)性測試題庫學生專用
- 2025年河北外國語學院單招職業(yè)傾向性測試題庫必考題
- 倉儲租賃居間合作批文
- 2025年益陽醫(yī)學高等??茖W校高職單招高職單招英語2016-2024歷年頻考點試題含答案解析
- 配套課件-前廳客房服務(wù)與管理
- 2025年度藥店營業(yè)員服務(wù)規(guī)范及合同約束協(xié)議3篇
- 工業(yè)和信息化部裝備工業(yè)發(fā)展中心2025年上半年應(yīng)屆畢業(yè)生招聘易考易錯模擬試題(共500題)試卷后附參考答案
- 2025年上半年浙江嘉興桐鄉(xiāng)市水務(wù)集團限公司招聘10人易考易錯模擬試題(共500題)試卷后附參考答案
- 重慶市2024-2025學年高一上學期期末聯(lián)考生物試卷(含答案)
- (八省聯(lián)考)2025年高考綜合改革適應(yīng)性演練 物理試卷合集(含答案逐題解析)
- 緊急疏散逃生方法
- 羊水栓塞護理應(yīng)急預案
- 2024年醫(yī)師定期考核臨床類考試題庫及答案(共500題)
- 2024版數(shù)據(jù)中心建設(shè)與運維服務(wù)合同協(xié)議書3篇
評論
0/150
提交評論