版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第11章Java操作Oracle數(shù)據(jù)庫(kù)11.1JDBC概述一、JDBCJDBC的全稱(chēng)是JavaDataBaseConnectivity,簡(jiǎn)稱(chēng)JDBC。它是Java訪問(wèn)關(guān)系型數(shù)據(jù)庫(kù)的規(guī)范,由一組用Java語(yǔ)言編寫(xiě)的接口和類(lèi)組成(一組API),主要用來(lái)規(guī)范Java客戶端程序如何訪問(wèn)數(shù)據(jù)庫(kù)。11.1JDBC概述二、API簡(jiǎn)介JDBCAPI主要位于java.sql包中,該包定義了一系列訪問(wèn)數(shù)據(jù)庫(kù)的接口和類(lèi)。Driver接口:是所有JDBC驅(qū)動(dòng)程序必須實(shí)現(xiàn)的接口,該接口專(zhuān)門(mén)提供給數(shù)據(jù)庫(kù)廠商使用。在編寫(xiě)JDBC程序時(shí),必須要把指定數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序或類(lèi)庫(kù)加載到項(xiàng)目的classpath中。DriverManager類(lèi):用于加載JDBC驅(qū)動(dòng)并創(chuàng)建與數(shù)據(jù)庫(kù)的連接。Connection接口:代表程序與數(shù)據(jù)庫(kù)的連接,負(fù)責(zé)和數(shù)據(jù)庫(kù)通訊。PreparedStatement接口:用于執(zhí)行包含動(dòng)態(tài)參數(shù)的SQL,增刪改查等。CallableStatement接口:用于數(shù)據(jù)庫(kù)中的SQL存儲(chǔ)過(guò)程。ResultSet接口:表示SELECT查詢語(yǔ)句得到的結(jié)果集,該結(jié)果集封裝在一個(gè)邏輯表格中。在ResultSet接口內(nèi)部有一個(gè)游標(biāo)操縱結(jié)果集。11.2Java程序連接Oracle數(shù)據(jù)庫(kù)一、連接過(guò)程Java程序連接Oracle數(shù)據(jù)庫(kù)需要先加載(注冊(cè))JDBC驅(qū)動(dòng)程序類(lèi),然后通過(guò)其中的Connection接口和DriverManager類(lèi)連接數(shù)據(jù)庫(kù)和控制數(shù)據(jù)源,Oracle數(shù)據(jù)庫(kù)的驅(qū)動(dòng)程序類(lèi)是oracle.jdbc.driver.OracleDriver。二、獲得連接對(duì)象示例代碼Class.forName(driver);Connectionconn=DriverManager.getConnection(url,user,password);11.3Java程序操作Oracle數(shù)據(jù)庫(kù)通過(guò)JDBC連接Oracle數(shù)據(jù)庫(kù)后,可以對(duì)數(shù)據(jù)庫(kù)中的數(shù)據(jù)進(jìn)行查詢、修改、插入、刪除等操作。對(duì)數(shù)據(jù)庫(kù)的最終操作還是要依賴于SQL語(yǔ)句。JDBC中的PreparedStatement和Statement對(duì)象都可以用于向數(shù)據(jù)庫(kù)發(fā)送SQL語(yǔ)句。一、創(chuàng)建PreparedStatement對(duì)象PreparedStatement對(duì)象需要通過(guò)Connection類(lèi)的prepareStatement()方法進(jìn)行創(chuàng)建,PreparedStatement對(duì)象創(chuàng)建成功后,可以調(diào)用其中的方法發(fā)送SQL語(yǔ)句。其語(yǔ)法格式如下:PreparedStatementpstmt=conn.prepareStatement(SQL);pstmt.executeUpdate();11.3Java程序操作Oracle數(shù)據(jù)庫(kù)二、查詢數(shù)據(jù)可以調(diào)用PreparedStatement對(duì)象的executeQuery()方法來(lái)發(fā)送查詢語(yǔ)句,它的返回值類(lèi)型是一個(gè)ResultSet對(duì)象。調(diào)用executeQuery()方法的語(yǔ)法格式如下:PreparedStatementpstmt=conn.prepareStatement(SQL);ResultSetrs=pstmt.executeQuery();ResultSet對(duì)象維護(hù)了一個(gè)數(shù)據(jù)行的游標(biāo),調(diào)用ResultSet.next()方法,可以讓游標(biāo)指向具體的數(shù)據(jù)行,進(jìn)行獲取該行的數(shù)據(jù)。三、插入、更新和刪除數(shù)據(jù)如果需要插入、更新和刪除數(shù)據(jù),則需要執(zhí)行PreparedStatement對(duì)象的executeUpdate()方法來(lái)實(shí)現(xiàn),此方法的返回值類(lèi)型為int,它返回的是影響的行數(shù)。調(diào)用executeUpdate()方法的語(yǔ)法格式如下:11.3Java程序操作Oracle數(shù)據(jù)庫(kù)StringSQL=“INSERT語(yǔ)句”;PreparedStatementpstmt=conn.prepareStatement(SQL);intresult=pstmt.executeUpdate();四、執(zhí)行任意SQL語(yǔ)句執(zhí)行事先未知的SQL語(yǔ)句,即有時(shí)編程無(wú)法得知是查詢還是更新語(yǔ)句,就無(wú)法使用上述方法傳遞SQL語(yǔ)句,可以用Statement對(duì)象的execute()方法來(lái)進(jìn)行傳遞,此方法的返回值類(lèi)型是布爾值,表示是否返回ResultSet,返回值為true表示執(zhí)行了查詢語(yǔ)句有查詢結(jié)果集返回,返回值為false表示執(zhí)行了更新語(yǔ)句無(wú)查詢結(jié)果集。Connectionconn=DriverManager.getConnection(url,user,password);Statementstmt=connection.createStatement();StringSQL="SELECT語(yǔ)句";booleanhasResult=stmt.execute(SQL);11.3Java程序操作Oracle數(shù)據(jù)庫(kù)五、關(guān)閉創(chuàng)建的對(duì)象當(dāng)數(shù)據(jù)庫(kù)所有操作結(jié)束后,需要關(guān)閉創(chuàng)建的對(duì)象從而釋放系統(tǒng)資源,關(guān)閉主要就是調(diào)用對(duì)象的close()方法。
11.4應(yīng)用舉例實(shí)現(xiàn)一個(gè)金融應(yīng)用場(chǎng)景數(shù)據(jù)庫(kù)用戶操作模塊的JDBC代碼,該應(yīng)用模塊可以完成用戶登錄、添加新用戶、用戶查詢、用戶銷(xiāo)戶、修改密碼等操作。一、用戶登錄該模塊實(shí)現(xiàn)用戶登錄功能,用戶名為注冊(cè)郵箱,用戶在登錄界面輸入郵箱賬號(hào)和密碼,程序讀取數(shù)據(jù)庫(kù)里client_tb表(用戶表)中存儲(chǔ)的郵箱賬號(hào)和密碼,與用戶輸入的數(shù)據(jù)進(jìn)行匹配。如果匹配成功,輸出登錄成功;匹配不成功則輸出用戶名或密碼錯(cuò)誤(包括該用戶不存在)。二、添加新用戶添加新用戶的操作是向client_tb表插入記錄,表中一條記錄代表
溫馨提示
- 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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年牛津上海版九年級(jí)化學(xué)下冊(cè)階段測(cè)試試卷
- 2025年滬教新版八年級(jí)英語(yǔ)下冊(cè)階段測(cè)試試卷含答案
- 2025年華東師大版七年級(jí)科學(xué)下冊(cè)階段測(cè)試試卷
- 《基金管理學(xué)》課件
- 2025年牛津譯林版必修2化學(xué)上冊(cè)階段測(cè)試試卷
- 城市供水改造以此合同為準(zhǔn)
- 建筑門(mén)窗施工合同:醫(yī)療機(jī)構(gòu)建設(shè)
- 網(wǎng)絡(luò)公司宿舍管理員招聘協(xié)議
- 酒店管理公司前臺(tái)聘用合同
- 城市藝術(shù)景觀石拱橋施工合同
- 2024-2025年第一學(xué)期小學(xué)德育工作總結(jié):點(diǎn)亮德育燈塔引領(lǐng)小學(xué)生全面成長(zhǎng)的逐夢(mèng)之旅
- 2024四川阿壩州事業(yè)單位和州直機(jī)關(guān)招聘691人歷年管理單位遴選500模擬題附帶答案詳解
- 麻醉科工作計(jì)劃
- 2024年新進(jìn)員工試用期考核標(biāo)準(zhǔn)3篇
- 《英美文化概況》課件
- 四川省2023年普通高中學(xué)業(yè)水平考試物理試卷 含解析
- 2024-2025學(xué)年人教版八年級(jí)上學(xué)期數(shù)學(xué)期末復(fù)習(xí)試題(含答案)
- 2024年醫(yī)院康復(fù)科年度工作總結(jié)(4篇)
- 五金耗材材料項(xiàng)目投標(biāo)方案(技術(shù)方案)
- 防網(wǎng)絡(luò)電信詐騙主題班會(huì)
- 中職無(wú)人機(jī)應(yīng)用技術(shù)跨行業(yè)人才培養(yǎng)方案
評(píng)論
0/150
提交評(píng)論