補(bǔ)充:JDBC數(shù)據(jù)庫(kù)訪問(wèn)_第1頁(yè)
補(bǔ)充:JDBC數(shù)據(jù)庫(kù)訪問(wèn)_第2頁(yè)
補(bǔ)充:JDBC數(shù)據(jù)庫(kù)訪問(wèn)_第3頁(yè)
補(bǔ)充:JDBC數(shù)據(jù)庫(kù)訪問(wèn)_第4頁(yè)
補(bǔ)充:JDBC數(shù)據(jù)庫(kù)訪問(wèn)_第5頁(yè)
已閱讀5頁(yè),還剩13頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1.JDBC簡(jiǎn)介與數(shù)據(jù)庫(kù)訪問(wèn)JDBC是Java數(shù)據(jù)庫(kù)連接API。

JavaDataBaseConnectivity

JDBC是Java應(yīng)用程序與數(shù)據(jù)庫(kù)的溝通橋梁,通過(guò)JDBC所提供的API,Java程序能很容易連接數(shù)據(jù)庫(kù)。簡(jiǎn)單的說(shuō),JDBC能完成三件事:與一個(gè)數(shù)據(jù)庫(kù)建立連接,有兩種方法:通過(guò)建立一個(gè)JDBC-ODBC橋接器,來(lái)訪問(wèn)數(shù)據(jù)庫(kù)JDBC直接加載數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序,來(lái)訪問(wèn)數(shù)據(jù)庫(kù)發(fā)送SQL語(yǔ)句處理數(shù)據(jù)庫(kù)返回的結(jié)果12.JDBCAPIJDBC與具體的某種數(shù)據(jù)庫(kù)連接時(shí)需要裝載與之對(duì)應(yīng)的驅(qū)動(dòng)程序,不過(guò)此種驅(qū)動(dòng)程序不需要我們自己去裝載,而是直接通過(guò)JDBCAPI類庫(kù)里的類來(lái)自動(dòng)裝載驅(qū)動(dòng)程序。這些API類庫(kù)一般都集中在java.sql包中。java.sql包中還包含了用于實(shí)現(xiàn)與數(shù)據(jù)庫(kù)連接的其它功能的類,包括與數(shù)據(jù)庫(kù)建立連接、傳送查詢、接受查詢結(jié)果等。2JDBC要做的三件事:與數(shù)據(jù)庫(kù)建立連接發(fā)送SQL語(yǔ)句處理返回的結(jié)果處理返回的結(jié)果發(fā)送SQL語(yǔ)句與數(shù)據(jù)庫(kù)建立連接縱覽JDBCAPIClass類DriverManager類Connection類Statement類由Connection類的createStatement()方法產(chǎn)生。PreparedStatement類由Connection類的PreparedStatement()方法產(chǎn)生。CallableStatement類由Connection類的prepareCall()方法產(chǎn)生。ResultSet類由Statement類或PreparedStatement類的executeQuery()方法產(chǎn)生。3JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果DriverManager類DriverManager類用于裝載驅(qū)動(dòng)程序。它所有的成員都是靜態(tài)成員,所以在程序中無(wú)須進(jìn)行實(shí)例化,直接通過(guò)類名就可以訪問(wèn)它。DriverManager的主要用途是通過(guò)getConnection方法來(lái)取得Connection對(duì)象引用。其格式為:

ConnectiongetConnection(Stringurl,Stringuser,Stringpassword);

其中各參數(shù)含義如下:url:指明數(shù)據(jù)庫(kù)定向位置,其具體格式由數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序約定,不同的數(shù)據(jù)庫(kù)格式不同。user:登錄數(shù)據(jù)庫(kù)的用戶password:登錄數(shù)據(jù)庫(kù)的密碼4JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果class.forName(className)方法使用java.lang.Class類的forName()方法可指定所要用的驅(qū)動(dòng)程序。forName的參數(shù)格式如下:class.forName(“[公司名].[數(shù)據(jù)庫(kù)名].[驅(qū)動(dòng)程序名]”);如:

class.forName(“oracle.jdbc.driver.OracleDriver”); class.forName(“com.mysql.jdbc.Driver”);5常見(jiàn)數(shù)據(jù)庫(kù)的連接方法class.forName(driverName);Connectioncon=DriverManager.getConnection(url,user,pw);driverName-驅(qū)動(dòng)程序名url-JDBC的URL

ORACLE數(shù)據(jù)庫(kù)

driverName=“oracle.jdbc.driver.OracleDriver”;

url=“jdbc:oracle:thin:@localhost:1521:orcl”;

SQLSERVER數(shù)據(jù)庫(kù)

driverName=“com.microsoft.jdbc.sqlserver.SQLServerDriver”;

url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs";

DB2數(shù)據(jù)庫(kù)

driverName="com.ibm.db2.jdbc.app.DB2Driver";

url="jdbc:db2://localhost:5000/sample";

通過(guò)ODBC橋接器

driverName=“sun.jdbc.odbc.JdbcOdbcDriver";

url="jdbc:odbc:Customers";6如裝載一個(gè)JDBC-ODBC橋驅(qū)動(dòng)程序,并連接一個(gè)student數(shù)據(jù)源,數(shù)據(jù)庫(kù)登錄用戶為abc,密碼為111,其實(shí)現(xiàn)如下:class.forName(“sun.jdbc.odbc.jdbcodbcDriver”);Connectioncon=DriverManager.getConnection(“jdbc:odbc:student”,”abc”,”111”);getConnection()方法返回一個(gè)連接類對(duì)象,假如連接成功,則此對(duì)象是指向數(shù)據(jù)庫(kù)的一個(gè)連接;假如連接失敗,此對(duì)象為null。7JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果Connection類Connection類是通過(guò)DriverManager.getConnection()方法取得的,表示驅(qū)動(dòng)程序提供的與數(shù)據(jù)庫(kù)連接的對(duì)象。它同時(shí)還可用于管理此連接,如向數(shù)據(jù)庫(kù)發(fā)送查詢和接收數(shù)據(jù)庫(kù)的查詢結(jié)果都是在它基礎(chǔ)上的,它還可以在完成同數(shù)據(jù)庫(kù)的連接的所有任務(wù)后關(guān)閉此連接。8Connection類的主要方法StatementcreateStatement():新建一個(gè)Statement對(duì)象PreparedStatementprepareStatement(String

sql):新建一個(gè)PreparedStatement對(duì)象setAutoCommit(boolean

sutoCommit):設(shè)置此連接是否為自動(dòng)提交方式voidclose():關(guān)閉同數(shù)據(jù)庫(kù)的連接并釋放所占用的JDBC資源boolean

isClosed():判斷是否還與數(shù)據(jù)庫(kù)連接著DatabaseMetaData

getMetaData():返回DatabaseMetaData對(duì)象,此對(duì)象包括表、sql格式和后備進(jìn)程描述信息。voidsetReadOnly(boolean

readOnly):設(shè)置連接為只讀……9JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果Statement類Statement類用來(lái)管理與在數(shù)據(jù)庫(kù)中查詢相關(guān)的一些事情,它的對(duì)象由Connection類的createStatement()方法產(chǎn)生,如:Statementstatement=con.createStatement();其主要方法有:ResultSetexecuteQuery(Stringsql):返回一個(gè)靜態(tài)的sql查詢結(jié)果intexecuteUpdate(Stringsql):執(zhí)行一個(gè)insert、update或delete的SQL命令,返回被影響行數(shù)voidclose():關(guān)閉同數(shù)據(jù)庫(kù)的連接和占用的JDBC資源intgetMaxRows():返回查詢結(jié)果中所允許包含的最多行數(shù)voidsetMaxRows():設(shè)置查詢結(jié)果中所允許包含的最多行數(shù)voidcancel():取消一個(gè)正在執(zhí)行的查詢……10JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果PreparedStatementPreparedStatement類的作用和Statement類相似。當(dāng)需要進(jìn)行一批類似的查詢時(shí),可以用PreparedStatement類來(lái)簡(jiǎn)化查詢。它的對(duì)象由Connection類的PreparedStatement()方法產(chǎn)生,如: PreparedStatementpreparedStatement=con.preparedStatement(“select*fromstudentwhereage=?andscore>=?”); preparedStatement.setString(1,21); preparedStatement.setString(2,60); ResultSetresult1=preparedStatement.executeQuery(); preparedStatement.setString(1,22); preparedStatement.setString(2,90); ResultSetresult2=preparedStatement.executeQuery();11CallableStatementCallableStatement用于執(zhí)行存儲(chǔ)過(guò)程,繼承PreparedStatment接口。它的對(duì)象由Connection類的prepareCall()方法產(chǎn)生。JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果12使用CallableStatement對(duì)象

執(zhí)行存儲(chǔ)過(guò)程CallableStatementstmt=con.prepareCall(“{callMyProcedure(?,?,?)}”);stmt.setInt(1,77);stmt.setString(2,”Ruby”);stmt.setInt(3,45);stmt.executeUpdate();/*存儲(chǔ)過(guò)程MyProcedure的SQL腳本*/CREATEPROCEDUREMyProcedure(snINNUMBER,nameINCHAR,ageINCHAR)AS BEGIN INSERTINTODEPTVALUES(sn,name,age); END;/13ResultSet類ResultSet類用來(lái)裝載查詢結(jié)果,并可以通過(guò)它的不同方法提取查詢結(jié)果;Statement、PreparedStatement對(duì)象用executeQuery()方法都將產(chǎn)生ResultSet對(duì)象。JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果14ResultSet類的常用方法StringgetString(intcolumnIndex);StringgetString(StringcolumnName);intgetInt(intcolumnIndex);intgetInt(StringcolumnName);java.io.InputStreamgetBinaryStream(StringcolumnName);Booleannext();Booleanprevious();intgetRow();voidclose();ResultSetMetaDatagetMetaData();Booleanabsolute(introw);JDBC要做的三件事:1.建立連接2.發(fā)送SQL語(yǔ)句3.返回的結(jié)果15JDBC要做的三件事:與數(shù)據(jù)庫(kù)建立連接發(fā)送SQL語(yǔ)句處理返回的結(jié)果處理返回的結(jié)果發(fā)送SQL語(yǔ)句與數(shù)據(jù)庫(kù)建立連接縱覽JDBCAPI兩個(gè)步驟建立連接:1、使用java.lang.Class類的forName()方法指定所要用的驅(qū)動(dòng)程序。2、使用DriverManager的getConnection()方法來(lái)取得Connection對(duì)象引用。Statement類用以管理與在數(shù)據(jù)庫(kù)中查詢相關(guān)的一些事情;由Connection類的createStatement()方法產(chǎn)生。PreparedStatement類用以進(jìn)行一批較類似的查詢;由Connection類的PreparedStatement()方法產(chǎn)生。CallableStatement類用以執(zhí)行存儲(chǔ)過(guò)程;由Connection類的prepareCall()方法產(chǎn)生。ResultSet類用以裝載查詢結(jié)果;由Statement類或PreparedStatement類的executeQuery()方法都可產(chǎn)生ResultSet對(duì)象。16JDBC要做的三件事:與數(shù)據(jù)庫(kù)建立連接發(fā)送SQL語(yǔ)句處理返回的結(jié)果處理返回的結(jié)果發(fā)送SQL語(yǔ)句與數(shù)據(jù)庫(kù)建立連接縱覽JDBCAPI兩個(gè)步驟建立連接:1、使用java.lang.Class類的forName()方法指定所要用的驅(qū)動(dòng)程序。2、使用DriverManager的getConnection()方法來(lái)取得Connection對(duì)象引用。Statement類用以管理與在數(shù)據(jù)庫(kù)中查詢相關(guān)的一些事情;由Connection類的createStatement()方法產(chǎn)

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論