Java Web程序設(shè)計(jì)(慕課版 第3版)-基于SSM 課件 第7章 數(shù)據(jù)庫技術(shù)_第1頁
Java Web程序設(shè)計(jì)(慕課版 第3版)-基于SSM 課件 第7章 數(shù)據(jù)庫技術(shù)_第2頁
Java Web程序設(shè)計(jì)(慕課版 第3版)-基于SSM 課件 第7章 數(shù)據(jù)庫技術(shù)_第3頁
Java Web程序設(shè)計(jì)(慕課版 第3版)-基于SSM 課件 第7章 數(shù)據(jù)庫技術(shù)_第4頁
Java Web程序設(shè)計(jì)(慕課版 第3版)-基于SSM 課件 第7章 數(shù)據(jù)庫技術(shù)_第5頁
已閱讀5頁,還剩22頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

第7章數(shù)據(jù)庫技術(shù)01JDBC概述02JDBC中的常用接口03 連接數(shù)據(jù)庫04數(shù)據(jù)庫操作技術(shù)1

JDBC概述JDBC技術(shù)JDBC的全稱為JavaDataBaseConnectivity,是一套面向?qū)ο蟮膽?yīng)用程序接口(API),制定了統(tǒng)一的訪問各類關(guān)系數(shù)據(jù)庫的標(biāo)準(zhǔn)接口,為各個(gè)數(shù)據(jù)庫廠商提供了標(biāo)準(zhǔn)接口的實(shí)現(xiàn)。通常情況下使用JDBC完成以下操作:(1)同數(shù)據(jù)庫建立連接;(2)向數(shù)據(jù)庫發(fā)送SQL語句;(3)處理從數(shù)據(jù)庫返回的結(jié)果。JDBC技術(shù)的優(yōu)缺點(diǎn)優(yōu)點(diǎn)JDBC與ODBC十分相似,便于軟件開發(fā)人員理解;JDBC使軟件開發(fā)人員從復(fù)雜的驅(qū)動程序編寫工作中解脫出來,可以完全專著與業(yè)務(wù)邏輯的開發(fā);JDBC支持多種關(guān)系型數(shù)據(jù)庫,大大增加了軟件的可移植性;JDBCAPI是面向?qū)ο蟮模浖_發(fā)人員可以將常用的方法進(jìn)行二次封裝,從而提高代碼的重用性。缺點(diǎn)通過JDBC訪問數(shù)據(jù)庫時(shí)速度將受到一定影響;雖然JDBCAPI是面向?qū)ο蟮?,但通過JDBC訪問數(shù)據(jù)庫依然是面向關(guān)系的;JDBC提供了對不同廠家的產(chǎn)品的支持,這將對數(shù)據(jù)源帶來影響。JDBC驅(qū)動程序JDBC-ODBCBridgeJDBC-NativeAPIBridgeJDBC-middlewarePureJDBCDriver2

JDBC中的常用接口驅(qū)動程序接口Driver通過java.lang.Class類的靜態(tài)方法forName(StringclassName),加載要連接數(shù)據(jù)庫的Driver類,該方法的入口參數(shù)為要加載Driver類的完整包名。Class.forName("com.mysql.jdbc.Driver");驅(qū)動程序管理器DriverManager方法名稱功能描述getConnection(Stringurl,Stringuser,Stringpassword)為靜態(tài)方法,用來獲得數(shù)據(jù)庫連接,有3個(gè)入口參數(shù),依次為要連接數(shù)據(jù)庫的URL、用戶名和密碼,返回值類型為java.sql.ConnectionsetLoginTimeout(intseconds)為靜態(tài)方法,用來設(shè)置每次等待建立數(shù)據(jù)庫連接的最長時(shí)間setLogWriter(java.io.PrintWriterout)為靜態(tài)方法,用來設(shè)置日志的輸出對象println(Stringmessage)為靜態(tài)方法,用來輸出指定消息到當(dāng)前的JDBC日志流DriverManager類提供的常用方法數(shù)據(jù)庫連接接口Connection方法名稱功能描述createStatement()創(chuàng)建并返回一個(gè)Statement實(shí)例,通常在執(zhí)行無參數(shù)的SQL語句時(shí)創(chuàng)建該實(shí)例prepareStatement()創(chuàng)建并返回一個(gè)PreparedStatement實(shí)例,通常在執(zhí)行包含參數(shù)的SQL語句時(shí)創(chuàng)建該實(shí)例,并對SQL語句進(jìn)行了預(yù)編譯處理prepareCall()創(chuàng)建并返回一個(gè)CallableStatement實(shí)例,通常在調(diào)用數(shù)據(jù)庫存儲過程時(shí)創(chuàng)建該實(shí)例setAutoCommit()設(shè)置當(dāng)前Connection實(shí)例的自動提交模式,默認(rèn)為true,即自動將更改同步到數(shù)據(jù)庫中,如果設(shè)為false,需要通過執(zhí)行commit()或rollback()方法手動將更改同步到數(shù)據(jù)庫中g(shù)etAutoCommit()查看當(dāng)前的Connection實(shí)例是否處于自動提交模式,如果是則返回true,否則返回falsesetSavepoint()在當(dāng)前事務(wù)中創(chuàng)建并返回一個(gè)Savepoint實(shí)例,前提條件是當(dāng)前的Connection實(shí)例不能處于自動提交模式,否則將拋出異常releaseSavepoint()從當(dāng)前事務(wù)中移除指定的Savepoint實(shí)例setReadOnly()設(shè)置當(dāng)前Connection實(shí)例的讀取模式,默認(rèn)為非只讀模式,不能在事務(wù)當(dāng)中執(zhí)行該操作,否則將拋出異常,有一個(gè)boolean型的入口參數(shù),設(shè)為true則表示開啟只讀模式,設(shè)為false則表示關(guān)閉只讀模式isReadOnly()查看當(dāng)前的Connection實(shí)例是否為只讀模式,如果是則返回true,否則返回falseisClosed()查看當(dāng)前的Connection實(shí)例是否被關(guān)閉,如果被關(guān)閉則返回true,否則返回falsecommit()將從上一次提交或回滾以來進(jìn)行的所有更改同步到數(shù)據(jù)庫,并釋放Connection實(shí)例當(dāng)前擁有的所有數(shù)據(jù)庫鎖定rollback()取消當(dāng)前事務(wù)中的所有更改,并釋放當(dāng)前Connection實(shí)例擁有的所有數(shù)據(jù)庫鎖定;該方法只能在非自動提交模式下使用,如果在自動提交模式下執(zhí)行該方法,將拋出異常;有一個(gè)入口參數(shù)為Savepoint實(shí)例的重載方法,用來取消Savepoint實(shí)例之后的所有更改,并釋放對應(yīng)的數(shù)據(jù)庫鎖定close()立即釋放Connection實(shí)例占用的數(shù)據(jù)庫和JDBC資源,即關(guān)閉數(shù)據(jù)庫連接執(zhí)行SQL語句接口Statement方法名稱功能描述executeQuery(Stringsql)執(zhí)行指定的靜態(tài)SELECT語句,并返回一個(gè)永遠(yuǎn)不能為null的ResultSet實(shí)例executeUpdate(Stringsql)執(zhí)行指定的靜態(tài)INSERT、UPDATE或DELETE語句,并返回一個(gè)int型數(shù)值,為同步更新記錄的條數(shù)clearBatch()清除位于Batch中的所有SQL語句,如果驅(qū)動程序不支持批量處理將拋出異常addBatch(Stringsql)將指定的SQL命令添加到Batch中,String型入口參數(shù)通常為靜態(tài)的INSERT或UPDATE語句,如果驅(qū)動程序不支持批量處理將拋出異常executeBatch()執(zhí)行Batch中的所有SQL語句,如果全部執(zhí)行成功,則返回由更新計(jì)數(shù)組成的數(shù)組,數(shù)組元素的排序與SQL語句的添加順序?qū)?yīng)

數(shù)組元素有以下幾種情況:①大于或等于零的數(shù),說明SQL語句執(zhí)行成功,為影響數(shù)據(jù)庫中行數(shù)的更新計(jì)數(shù);②

2,說明SQL語句執(zhí)行成功,但未得到受影響的行數(shù);③

3,說明SQL語句執(zhí)行失敗,僅當(dāng)執(zhí)行失敗后繼續(xù)執(zhí)行后面的SQL語句時(shí)出現(xiàn)。如果驅(qū)動程序不支持批量,或者未能成功執(zhí)行Batch中的SQL語句之一,將拋出異常close()立即釋放Statement實(shí)例占用的數(shù)據(jù)庫和JDBC資源,即關(guān)閉Statement實(shí)例執(zhí)行動態(tài)SQL語句接口PreparedStatementPreparedStatementps=connection.prepareStatement("select*fromtable_namewhereid>?and(name=?orname=?)");ps.setInt(1,1);ps.setString(2,"wgh");ps.setObject(3,"sk");ResultSetrs=ps.executeQuery();PreparedStatement的使用方法如下:方法名稱功能描述executeQuery()執(zhí)行前面包含參數(shù)的動態(tài)SELECT語句,并返回一個(gè)永遠(yuǎn)不能為null的ResultSet實(shí)例executeUpdate()執(zhí)行前面包含參數(shù)的動態(tài)INSERT、UPDATE或DELETE語句,并返回一個(gè)int型數(shù)值,為同步更新記錄的條數(shù)clearParameters()清除當(dāng)前所有參數(shù)的值close()立即釋放Statement實(shí)例占用的數(shù)據(jù)庫和JDBC資源,即關(guān)閉Statement實(shí)例訪問結(jié)果集接口ResultSet方法名稱功能描述first()移動指針到第一行;如果結(jié)果集為空則返回false,否則返回true;如果結(jié)果集類型為TYPE_FORWARD_ONLY將拋出異常last()移動指針到最后一行;如果結(jié)果集為空則返回false,否則返回true;如果結(jié)果集類型為TYPE_FORWARD_ONLY將拋出異常previous()移動指針到上一行;如果存在上一行則返回true,否則返回false;如果結(jié)果集類型為TYPE_FORWARD_ONLY將拋出異常next()移動指針到下一行;指針最初位于第一行之前,第一次調(diào)用該方法將移動到第一行;如果存在下一行則返回true,否則返回falsejava.sql.ResultSet接口類似于一個(gè)數(shù)據(jù)表,通過該接口的實(shí)例可以獲得檢索結(jié)果集,以及對應(yīng)數(shù)據(jù)表的相關(guān)信息,例如列名和類型等,ResultSet實(shí)例通過執(zhí)行查詢數(shù)據(jù)庫的語句生成。3

連接數(shù)據(jù)庫加載JDBC驅(qū)動程序try{Class.forName("com.mysql.jdbc.Driver");}catch(ClassNotFoundExceptione){System.out.println("加載數(shù)據(jù)庫驅(qū)動時(shí)拋出異常,內(nèi)容如下:");e.printStackTrace();}通常將負(fù)責(zé)加載驅(qū)動的代碼放在static塊中,這樣做的好處是只有static塊所在的類第一次被加載時(shí)才加載數(shù)據(jù)庫驅(qū)動,避免重復(fù)加載驅(qū)動程序,浪費(fèi)計(jì)算機(jī)資源。創(chuàng)建數(shù)據(jù)庫連接Connectionconn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/db_database24","root","123456");數(shù)據(jù)庫URL數(shù)據(jù)庫賬號數(shù)據(jù)庫密碼返回的數(shù)據(jù)庫連接執(zhí)行SQL語句Statement該類型的實(shí)例只能用來執(zhí)行靜態(tài)的SQL語句;PreparedStatement該類型的實(shí)例增加了執(zhí)行動態(tài)SQL語句的功能;CallableStatement該類型的實(shí)例增加了執(zhí)行數(shù)據(jù)庫存儲過程的功能。獲得查詢結(jié)果通過Statement接口的executeUpdate()或executeQuery()方法,可以執(zhí)行SQL語句,同時(shí)將返回執(zhí)行結(jié)果。如果執(zhí)行的是executeUpdate()方法,將返回一個(gè)int型數(shù)值,代表影響數(shù)據(jù)庫記錄的條數(shù),即插入、修改或刪除記錄的條數(shù);如果執(zhí)行的是executeQuery()方法,將返回一個(gè)ResultSet型的結(jié)果集,其中不僅包含所有滿足查詢條件的記錄,關(guān)閉連接resultSet.close();statement.close();connection.close();使用Connection,Statement和ResultSet實(shí)例的close()方法,并且在關(guān)閉時(shí)建議按照以下的順序:4

數(shù)據(jù)庫操作技術(shù)查詢操作try{Class.forName("com.mysql.jdbc.Driver");}catch(ClassNotFoundExceptione){e.printStackTrace();}Connectionconn=DriverManager.getConnection("jdbc:mysql://localhost/db_database24?useUnicode=true&characterEncoding=utf8","root","123456");Statementstmt=conn.createStatement();ResultSetrs=stmt.executeQuery("select*fromtb_userwhereusername='admin'");while(rs.next()){out.println("用戶名:"+rs.getString(2)+"密碼:"+rs.getString(3));}rs.close();stmt.close();conn.close();查詢天下淘商城用戶賬戶信息添加操作添加天下淘添加新用戶賬戶信息Statementstmt=conn.createStatement();intrtn=stmt.executeUpdate("insertintotb_user(username,password)values('hope','111')");PreparedStatementpStmt=conn.prepareStatement("insertintotb_user(username,password)values(?,?)");pStmt.setString(1,"dream");pStmt.setString(2,"111");intrtn=pStmt.executeUpdate();修改操作修改天下淘添加新用戶賬戶信息。Statementstmt=conn.createStatement();intrtn=stmt.executeUpdate("updatetb_usersetusername='hope',password='222'whereusername='dream'");PreparedStatementpStmt=conn.prepareStatement("updatetb_userset

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論