《Oracle大型數(shù)據(jù)庫基礎(chǔ)開發(fā)教程》(微課視頻版)課件 第11章 Java 操作 Oracle數(shù)據(jù)庫_第1頁
《Oracle大型數(shù)據(jù)庫基礎(chǔ)開發(fā)教程》(微課視頻版)課件 第11章 Java 操作 Oracle數(shù)據(jù)庫_第2頁
《Oracle大型數(shù)據(jù)庫基礎(chǔ)開發(fā)教程》(微課視頻版)課件 第11章 Java 操作 Oracle數(shù)據(jù)庫_第3頁
《Oracle大型數(shù)據(jù)庫基礎(chǔ)開發(fā)教程》(微課視頻版)課件 第11章 Java 操作 Oracle數(shù)據(jù)庫_第4頁
《Oracle大型數(shù)據(jù)庫基礎(chǔ)開發(fā)教程》(微課視頻版)課件 第11章 Java 操作 Oracle數(shù)據(jù)庫_第5頁
已閱讀5頁,還剩5頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

第11章Java操作Oracle數(shù)據(jù)庫11.1JDBC概述一、JDBCJDBC的全稱是JavaDataBaseConnectivity,簡稱JDBC。它是Java訪問關(guān)系型數(shù)據(jù)庫的規(guī)范,由一組用Java語言編寫的接口和類組成(一組API),主要用來規(guī)范Java客戶端程序如何訪問數(shù)據(jù)庫。11.1JDBC概述二、API簡介JDBCAPI主要位于java.sql包中,該包定義了一系列訪問數(shù)據(jù)庫的接口和類。Driver接口:是所有JDBC驅(qū)動程序必須實現(xiàn)的接口,該接口專門提供給數(shù)據(jù)庫廠商使用。在編寫JDBC程序時,必須要把指定數(shù)據(jù)庫驅(qū)動程序或類庫加載到項目的classpath中。DriverManager類:用于加載JDBC驅(qū)動并創(chuàng)建與數(shù)據(jù)庫的連接。Connection接口:代表程序與數(shù)據(jù)庫的連接,負(fù)責(zé)和數(shù)據(jù)庫通訊。PreparedStatement接口:用于執(zhí)行包含動態(tài)參數(shù)的SQL,增刪改查等。CallableStatement接口:用于數(shù)據(jù)庫中的SQL存儲過程。ResultSet接口:表示SELECT查詢語句得到的結(jié)果集,該結(jié)果集封裝在一個邏輯表格中。在ResultSet接口內(nèi)部有一個游標(biāo)操縱結(jié)果集。11.2Java程序連接Oracle數(shù)據(jù)庫一、連接過程Java程序連接Oracle數(shù)據(jù)庫需要先加載(注冊)JDBC驅(qū)動程序類,然后通過其中的Connection接口和DriverManager類連接數(shù)據(jù)庫和控制數(shù)據(jù)源,Oracle數(shù)據(jù)庫的驅(qū)動程序類是oracle.jdbc.driver.OracleDriver。二、獲得連接對象示例代碼Class.forName(driver);Connectionconn=DriverManager.getConnection(url,user,password);11.3Java程序操作Oracle數(shù)據(jù)庫通過JDBC連接Oracle數(shù)據(jù)庫后,可以對數(shù)據(jù)庫中的數(shù)據(jù)進行查詢、修改、插入、刪除等操作。對數(shù)據(jù)庫的最終操作還是要依賴于SQL語句。JDBC中的PreparedStatement和Statement對象都可以用于向數(shù)據(jù)庫發(fā)送SQL語句。一、創(chuàng)建PreparedStatement對象PreparedStatement對象需要通過Connection類的prepareStatement()方法進行創(chuàng)建,PreparedStatement對象創(chuàng)建成功后,可以調(diào)用其中的方法發(fā)送SQL語句。其語法格式如下:PreparedStatementpstmt=conn.prepareStatement(SQL);pstmt.executeUpdate();11.3Java程序操作Oracle數(shù)據(jù)庫二、查詢數(shù)據(jù)可以調(diào)用PreparedStatement對象的executeQuery()方法來發(fā)送查詢語句,它的返回值類型是一個ResultSet對象。調(diào)用executeQuery()方法的語法格式如下:PreparedStatementpstmt=conn.prepareStatement(SQL);ResultSetrs=pstmt.executeQuery();ResultSet對象維護了一個數(shù)據(jù)行的游標(biāo),調(diào)用ResultSet.next()方法,可以讓游標(biāo)指向具體的數(shù)據(jù)行,進行獲取該行的數(shù)據(jù)。三、插入、更新和刪除數(shù)據(jù)如果需要插入、更新和刪除數(shù)據(jù),則需要執(zhí)行PreparedStatement對象的executeUpdate()方法來實現(xiàn),此方法的返回值類型為int,它返回的是影響的行數(shù)。調(diào)用executeUpdate()方法的語法格式如下:11.3Java程序操作Oracle數(shù)據(jù)庫StringSQL=“INSERT語句”;PreparedStatementpstmt=conn.prepareStatement(SQL);intresult=pstmt.executeUpdate();四、執(zhí)行任意SQL語句執(zhí)行事先未知的SQL語句,即有時編程無法得知是查詢還是更新語句,就無法使用上述方法傳遞SQL語句,可以用Statement對象的execute()方法來進行傳遞,此方法的返回值類型是布爾值,表示是否返回ResultSet,返回值為true表示執(zhí)行了查詢語句有查詢結(jié)果集返回,返回值為false表示執(zhí)行了更新語句無查詢結(jié)果集。Connectionconn=DriverManager.getConnection(url,user,password);Statementstmt=connection.createStatement();StringSQL="SELECT語句";booleanhasResult=stmt.execute(SQL);11.3Java程序操作Oracle數(shù)據(jù)庫五、關(guān)閉創(chuàng)建的對象當(dāng)數(shù)據(jù)庫所有操作結(jié)束后,需要關(guān)閉創(chuàng)建的對象從而釋放系統(tǒng)資源,關(guān)閉主要就是調(diào)用對象的close()方法。

11.4應(yīng)用舉例實現(xiàn)一個金融應(yīng)用場景數(shù)據(jù)庫用戶操作模塊的JDBC代碼,該應(yīng)用模塊可以完成用戶登錄、添加新用戶、用戶查詢、用戶銷戶、修改密碼等操作。一、用戶登錄該模塊實現(xiàn)用戶登錄功能,用戶名為注冊郵箱,用戶在登錄界面輸入郵箱賬號和密碼,程序讀取數(shù)據(jù)庫里client_tb表(用戶表)中存儲的郵箱賬號和密碼,與用戶輸入的數(shù)據(jù)進行匹配。如果匹配成功,輸出登錄成功;匹配不成功則輸出用戶名或密碼錯誤(包括該用戶不存在)。二、添加新用戶添加新用戶的操作是向client_tb表插入記錄,表中一條記錄代表

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論