




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、JDBC基本概念和應(yīng)用講課內(nèi)容JDBC基本概念如何通過(guò)JDBC訪問(wèn)數(shù)據(jù)庫(kù)JDBC基本概念JDBC為java開發(fā)者使用數(shù)據(jù)庫(kù)提供了統(tǒng)一的編程接口,它由一組java類和接口組成。是java程序與數(shù)據(jù)庫(kù)系統(tǒng)通信的標(biāo)準(zhǔn)API。JDBC API 使得開發(fā)人員可以使用純java的方式來(lái)連接數(shù)據(jù)庫(kù),并執(zhí)行操作。JDBC的結(jié)構(gòu)程序包主要的類Jdbc的幾種類型JDBC的兩個(gè)程序包(核心API)Javax.sql (擴(kuò)展API) Jdbc網(wǎng)站:(核心API)這個(gè)寶中的類主要針對(duì)基本的數(shù)據(jù)庫(kù)變成服務(wù),如生成連接、執(zhí)行語(yǔ)句以及準(zhǔn)備語(yǔ)句和運(yùn)行批處理查詢等。包同時(shí)還提供了一些高級(jí)的處理,比如批處理更新、事務(wù)隔離和可滾動(dòng)結(jié)
2、果集等。Javax.sql (擴(kuò)展API) 它主要為數(shù)據(jù)庫(kù)方面的高級(jí)操作提供了接口和類。如連接管理、分布式事務(wù)和行集等。JDBC常用接口Driver接口DriverManager接口Connection接口接口Statement接口Result接口Driver接口Driver接口由數(shù)據(jù)庫(kù)廠家提供,對(duì)于java開發(fā)者而言,只需要使用Driver接口就可以了。在編程中要連接數(shù)據(jù)庫(kù),必須先裝載特定廠商的數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序。不同的數(shù)據(jù)庫(kù)有不同的裝載方法。裝載驅(qū)動(dòng)裝載JDBC-ODBC驅(qū)動(dòng):Class.forName(“”);裝載MS SQL Server驅(qū)動(dòng):Class.forName(“”);裝載驅(qū)動(dòng)裝
3、載MySql驅(qū)動(dòng)Class.forName(“”);裝載Oracle驅(qū)動(dòng)Class.forName(“”);DriverManager接口DriverManager是JDBC的管理層,作用于用戶和驅(qū)動(dòng)程序之間。DriverManager跟蹤可用的驅(qū)動(dòng)程序,并在數(shù)據(jù)庫(kù)和相應(yīng)的驅(qū)動(dòng)程序之間建立連接。DriverManager處理驅(qū)動(dòng)程序登陸時(shí)間限制、跟蹤消息的顯示等。Connection接口Connection與特定數(shù)據(jù)庫(kù)的連接(會(huì)話),在連接上下文中執(zhí)行 SQL 語(yǔ)句并返回結(jié)果。DriverManager的getConnection()方法建立在JDBC URL中定義的數(shù)據(jù)庫(kù)Connection
4、連接上: Connection con= DriverManager.getConnection(url,login,password);Statement接口用于執(zhí)行靜態(tài) SQL 語(yǔ)句并返回它所生成結(jié)果的對(duì)象。一般情況下使用connection.createStatement()方法可以得到Statement實(shí)例。Statement接口三種Statement對(duì)象: Statement、PreparedStatement和CallableStatement。常用的Statement方法: execute():運(yùn)行語(yǔ)句,返回是否有結(jié)果集。 executeQuerty():運(yùn)行查詢語(yǔ)句,返回Res
5、ultSet結(jié)果集。 executeUpdate():運(yùn)行更新操作,返回更新的行數(shù)。ResultSet接口Statement執(zhí)行SQL語(yǔ)句時(shí)返回ResultSet結(jié)果集。ResultSet提供的檢索不同類型字段的方法,常用的有: getString():獲得在數(shù)據(jù)庫(kù)里是varchar、char等數(shù)據(jù)類型的對(duì)象。 getFloar():獲得雜數(shù)據(jù)庫(kù)里是Float類型的對(duì)象。ResultSet接口getDate():獲得在數(shù)據(jù)庫(kù)里面是Date類型的數(shù)據(jù)。getBoolean():獲得在數(shù)據(jù)庫(kù)里面是Boolean類型的數(shù)據(jù)。getObject():在Sql中無(wú)對(duì)應(yīng)類型,獲得序列化對(duì)象。JDBC的幾種
6、類型數(shù)據(jù)庫(kù)廠商一般會(huì)提供一組API訪問(wèn)數(shù)據(jù)庫(kù)。流行的數(shù)據(jù)庫(kù)如Oracle、SQL Server、Sybase、Informix都提供了專用的API。JDBC的幾種類型Type 1 JDBC-ODBC橋Type 2 部分java部分本機(jī)驅(qū)動(dòng)程序Type 3 中間數(shù)據(jù)訪問(wèn)服務(wù)器Type 4 純java驅(qū)動(dòng)程序Type 1 JDBC-ODBC橋JDBC Type 1 驅(qū)動(dòng)程序基于 JDBC-ODBC 橋。它是把JDBC操作翻譯成對(duì)于的ODBC調(diào)用。優(yōu)點(diǎn):可以訪問(wèn)所有ODBC可以訪問(wèn)的數(shù)據(jù)庫(kù)。缺點(diǎn):執(zhí)行效率低。Type 1 JDBC-ODBC橋Type 2 部分java部分本機(jī)驅(qū)動(dòng)程序JDBC Typ
7、e 2 驅(qū)動(dòng)程序依靠特定于操作系統(tǒng)的庫(kù)(共享庫(kù))來(lái)與 RDBMS 通信。應(yīng)用程序?qū)⒀b入這種 JDBC 驅(qū)動(dòng)程序,而驅(qū)動(dòng)程序?qū)⑹褂霉蚕韼?kù)來(lái)與 數(shù)據(jù)庫(kù) 服務(wù)器通信。Type 2 部分java部分本機(jī)驅(qū)動(dòng)程序Type 3 中間數(shù)據(jù)訪問(wèn)服務(wù)器JDBC Type 3 驅(qū)動(dòng)程序?qū)?yīng)用程序與中間件服務(wù)器連接,中間件服務(wù)器將應(yīng)用程序的JDBC調(diào)用映射到適當(dāng)?shù)臄?shù)據(jù)庫(kù)驅(qū)動(dòng)程序上。WebLogic的驅(qū)動(dòng)池就是屬于type3類型。Type 3 中間數(shù)據(jù)訪問(wèn)服務(wù)器Type 4 純java驅(qū)動(dòng)程序Type 4 驅(qū)動(dòng)程序是僅用于 Java 的 JDBC 驅(qū)動(dòng)程序,它直接連接到數(shù)據(jù)庫(kù)服務(wù)器。Type 4 純java驅(qū)動(dòng)程序J
8、DBC object, interface modelDriver ManagerDriverResultSetConnectionStatementPreparedStatementCallableStatementRegisterProvideExecuteResultExtendsExtendsJDBC的使用程序?qū)懽鞑襟E使用實(shí)例JDBC 之程序?qū)懽鞑襟E1.注冊(cè)并載入特定的 Database DriverClass.forName(“”);2.利用 Driver Manager 建立DB ConnectionConnection conn = DriverManager.getConnec
9、tion(“jdbc:odbc:myDB”, “user”,”pw”);3.利用 Connection對(duì)象執(zhí)行 SQL 語(yǔ)句并返回它所生成結(jié)果的對(duì)象。 Statement stmt = conn.createStatement( );JDBC 之程序?qū)懽鞑襟E4.利用 Statement 執(zhí)行 SQL Statement必要時(shí)取得 ResultSet referenceResultSets rs = stmt.executeQuery(“Select * from Book”);5.利用 ResultSet 讀取相關(guān)資料rs.getXXX(“fieldName”);對(duì)象及連接;ResultSet
10、 Statement Connection實(shí)例一 jdbc-odbc橋方式連接Access連接數(shù)據(jù)庫(kù)JDBC-ODBC連接數(shù)據(jù)庫(kù) Connection con = null; try /調(diào)用JDBC-ODBC 驅(qū)動(dòng)程序 Class.forName(sun.jdbc.odbc.JdbcOdbcDriver); /建立連接 con = DriverManager.getConnection(jdbc:odbc:MS Access Database;DBQ=.databaseCompany.mdb); Statement stmt = con.createStatement(); 連接數(shù)據(jù)庫(kù)JDBC
11、-ODBC/利用 Statement 執(zhí)行 SQL Statement 并保存到ResultSet 中。ResultSet rst = stmt.executeQuery(SELECT chCompanyName FROM Company;);/處理結(jié)果集 while (rst.next() System.out.println(rst.getString(chCompanyName); catch (Exception e) e.printStackTrace(); 不同數(shù)據(jù)庫(kù)廠商的JDBC驅(qū)動(dòng)的使用Microsoft Access DatabaseMicrosoft SQL ServerM
12、ySQL DatabaseOracle DatabaseSybase DatabaseMicrosoft Access Database語(yǔ)法:/調(diào)用JDBC-ODBC 驅(qū)動(dòng)程序Class.forName(sun.jdbc.odbc.JdbcOdbcDriver);/建立連接con = DriverManager.getConnection(jdbc:odbc:MS Access Database;DBQ=.databaseCompany.mdb);Microsoft SQL Server語(yǔ)法:Class.forName(net.sourceforge.jtds.jdbc.Driver );Co
13、nnection 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語(yǔ)法:Class.forName(com.mysql.jdbc.Driver);Connection con = DriverManager.getConnection(jdbc:mysql:/host:port/database,user,password);Oracle Database語(yǔ)法:Class.forName(oracle.jdbc.driver.OracleDriver);Connection con = DriverManager.getConnect
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 企業(yè)培訓(xùn)現(xiàn)場(chǎng)課件
- 車間承包與市場(chǎng)拓展合作框架協(xié)議書
- 有限合伙公司分紅方案
- 餐飲企業(yè)股權(quán)激勵(lì)方案與合同書
- 成都市二手房買賣糾紛調(diào)解及仲裁服務(wù)合同
- 舊改項(xiàng)目拆遷安置房交易安全保障合同
- 新能源汽車推廣與市場(chǎng)拓展合同范本
- 廟會(huì)小吃承包方案
- 文物的面試題及答案
- 農(nóng)藥污染與健康
- 2025全國(guó)市場(chǎng)監(jiān)督管理法律知識(shí)競(jìng)賽測(cè)試題庫(kù)(含答案解析)
- 長(zhǎng)螺旋鉆孔灌注樁施工培訓(xùn)
- 頸動(dòng)脈狹窄支架術(shù)后護(hù)理
- 時(shí)序數(shù)據(jù)庫(kù)數(shù)據(jù)壓縮算法的研究與應(yīng)用
- 護(hù)理領(lǐng)域中的創(chuàng)造性焦慮研究進(jìn)展
- 醫(yī)院財(cái)務(wù)人員培訓(xùn)課程
- 爆破三員培訓(xùn)
- 浙江首考2025年1月普通高等學(xué)校招生全國(guó)統(tǒng)一考試 歷史 含答案
- 2025重慶電費(fèi)收費(fèi)標(biāo)準(zhǔn)
- 露天采石場(chǎng)應(yīng)急預(yù)案
- 2025-2030中國(guó)水溶性肥料行業(yè)市場(chǎng)發(fā)展分析及前景趨勢(shì)與投資研究報(bào)告
評(píng)論
0/150
提交評(píng)論