JavaWeb程序設(shè)計(jì) 課件 ch06 JSP訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)_第1頁(yè)
JavaWeb程序設(shè)計(jì) 課件 ch06 JSP訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)_第2頁(yè)
JavaWeb程序設(shè)計(jì) 課件 ch06 JSP訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)_第3頁(yè)
JavaWeb程序設(shè)計(jì) 課件 ch06 JSP訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)_第4頁(yè)
JavaWeb程序設(shè)計(jì) 課件 ch06 JSP訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)_第5頁(yè)
已閱讀5頁(yè),還剩29頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

第6章JSP訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)本課教學(xué)內(nèi)容JDBC簡(jiǎn)介建立ODBC數(shù)據(jù)源JDBC操作使用PreparedStatement事務(wù)使用廠(chǎng)商驅(qū)動(dòng)進(jìn)行數(shù)據(jù)庫(kù)連接JDBC簡(jiǎn)介商業(yè)應(yīng)用的后臺(tái)數(shù)據(jù)一般存放在數(shù)據(jù)庫(kù)中,很明顯,可以通過(guò)Java代碼來(lái)訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)。在Java技術(shù)系列中,訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)的技術(shù)叫做JDBC,它提供了一系列的API,讓Java語(yǔ)言編寫(xiě)的代碼連接數(shù)據(jù)庫(kù),對(duì)數(shù)據(jù)庫(kù)的數(shù)據(jù)進(jìn)行添加、刪除、修改和查詢(xún)JDBC簡(jiǎn)介JDBC中以下類(lèi)或接口java.sql.Connection:負(fù)責(zé)連接數(shù)據(jù)庫(kù)

java.sql.Statement:負(fù)責(zé)執(zhí)行數(shù)據(jù)庫(kù)SQL語(yǔ)句java.sql.ResultSet:負(fù)責(zé)存放查詢(xún)結(jié)果JDBC簡(jiǎn)介針對(duì)不同類(lèi)型的數(shù)據(jù)庫(kù),JDBC機(jī)制中提供了"驅(qū)動(dòng)程序"的的概念。對(duì)于不同的數(shù)據(jù)庫(kù),程序只需要使用不同的驅(qū)動(dòng)廠(chǎng)商驅(qū)動(dòng)連接數(shù)據(jù)庫(kù)JDBC簡(jiǎn)介安裝數(shù)據(jù)庫(kù)廠(chǎng)商驅(qū)動(dòng),需要去各自的數(shù)據(jù)庫(kù)廠(chǎng)商網(wǎng)站下載驅(qū)動(dòng)包,用戶(hù)也許覺(jué)得很麻煩。此時(shí),微軟公司提供了一個(gè)解決的方案。在微軟公司的Windows中,預(yù)先設(shè)計(jì)了一個(gè)ODBC(OpenDatabaseConnectivity,開(kāi)放數(shù)據(jù)庫(kù)互連)功能,由于ODBC是微軟公司的產(chǎn)品,因此它幾乎可以連接到所有在Windows平臺(tái)下運(yùn)行的數(shù)據(jù)庫(kù),由它連接到特定的數(shù)據(jù)庫(kù),不需要具體的驅(qū)動(dòng)。而JDBC就只需要連接到ODBC就可以了

JDBC簡(jiǎn)介ODBC驅(qū)動(dòng)連接數(shù)據(jù)庫(kù)建立ODBC數(shù)據(jù)源在使用ODBC之前,需要配置ODBC的數(shù)據(jù)源,讓ODBC知道連接的具體數(shù)據(jù)庫(kù)ODBC支持連接到各種數(shù)據(jù)庫(kù)。如Oracle、MySQL、MSSQLServer等,具體的設(shè)置詳見(jiàn)課本圖解過(guò)程建立ODBC數(shù)據(jù)源在配置時(shí),要注意:access的數(shù)據(jù)源驅(qū)動(dòng)器都是32位的,64位機(jī)上可能會(huì)找不到access數(shù)據(jù)源驅(qū)動(dòng)器。對(duì)于64位機(jī),可以打開(kāi)32位版本的ODBC管理工具,其界面和設(shè)置過(guò)程與32位的相同。由于JDK1.8及以上的版本都已經(jīng)不再包含access橋接驅(qū)動(dòng),在使用JDBC-ODBC橋接方式時(shí),需要下載access驅(qū)動(dòng)的jar包,具體操作方法大家可以參見(jiàn)其他詳細(xì)文檔。建立ODBC數(shù)據(jù)源操作如下:首先在控制面板中選擇"管理工具",雙擊"數(shù)據(jù)源(ODBC)圖標(biāo)"建立ODBC數(shù)據(jù)源操作如下:在"ODBC數(shù)據(jù)源管理器"的"系統(tǒng)DSN"選項(xiàng)卡中單擊"添加"按鈕建立ODBC數(shù)據(jù)源操作如下: 從彈出的"創(chuàng)建新數(shù)據(jù)源"窗口的數(shù)據(jù)源名稱(chēng)列表中選擇"MicrosoftAccesDriver(*.mdb)"并單擊"完成"按鈕建立ODBC數(shù)據(jù)源操作如下:在彈出的"ODBCMicrosoftAccess安裝"窗口的"數(shù)據(jù)源名"文本框輸入自定義的數(shù)據(jù)源名稱(chēng),然后點(diǎn)擊"選擇"按鈕,選擇Access數(shù)據(jù)庫(kù)所在的目錄,得到的結(jié)果如圖JDBC操作JDBC的操作分為4個(gè)步驟:通過(guò)JDBC連接到ODBC,并獲取連接對(duì)象Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");Connectionconn=DriverManager.getConnection("jdbc:odbc:DSSchool");JDBC操作

使用Statement接口運(yùn)行SQL語(yǔ)句Statementstat=conn.createStatement();stat.executeQuery(SQL語(yǔ)句);//查詢(xún)或者

stat.executeUpdate(SQL語(yǔ)句);//添加、刪除或修改

JDBC操作處理SQL語(yǔ)句運(yùn)行結(jié)果關(guān)閉數(shù)據(jù)庫(kù)連接:stat.close();conn.close();添加數(shù)據(jù)具體添加案例見(jiàn)課本在這里,重點(diǎn)介紹下面一句代碼: inti=stat.executeUpdate(sql);

它返回一個(gè)整型,意思為這條sql語(yǔ)句執(zhí)行受影響的行數(shù),即成功添加的條數(shù)刪除、修改數(shù)據(jù)具體代碼案例見(jiàn)課本兩種操作均調(diào)用stat.executeUpdate(sql),并返回一個(gè)整型量查詢(xún)數(shù)據(jù)具體代碼案例見(jiàn)課本查詢(xún)格式: ResultSetrs=stat.executeQuery(sql);查詢(xún)到的結(jié)果放入ResultSet中,實(shí)際上是一個(gè)小表格查詢(xún)數(shù)據(jù)游標(biāo) 是在ResultSet中一個(gè)可以移動(dòng)的指針,它指向一行數(shù)據(jù)。初始時(shí)指向第一行的前一行,實(shí)際上不指向任何數(shù)據(jù)。rs.next()可以將游標(biāo)移到下一行,它的返回值是一個(gè)布爾類(lèi)型,即如果下一行有數(shù)據(jù)則返回為true,否則為flase。很明顯,可以使用rs.next()配上while循環(huán)來(lái)對(duì)結(jié)果進(jìn)行遍歷查詢(xún)數(shù)據(jù)游標(biāo) 當(dāng)游標(biāo)指向某一行,可以通過(guò)ResultSet的getXXX("列名")方法得到這一行的某個(gè)數(shù)據(jù), XXX是該列的數(shù)據(jù)類(lèi)型,可以是String,也可以是int等,但是所有類(lèi)型的數(shù)據(jù)都可以用getString()方法獲得。除了通過(guò)列名獲得數(shù)據(jù)外,還可以通過(guò)列的編號(hào)來(lái)獲得查詢(xún)數(shù)據(jù)關(guān)于游標(biāo)的注意 游標(biāo)的初始值并不是指向第1行數(shù)據(jù),而是指向第1行的前面那條數(shù)據(jù)。所以必須要運(yùn)行一次next()函數(shù)之后,才能從開(kāi)始取數(shù)據(jù),如果強(qiáng)行取則會(huì)找不到該列而報(bào)錯(cuò)查詢(xún)數(shù)據(jù)關(guān)于游標(biāo)的注意從某一行中通過(guò)getXXX()方法取數(shù)據(jù)每一列只能取一次,超過(guò)一次,程序?qū)?huì)報(bào)錯(cuò),如果需要重復(fù)使用某列數(shù)據(jù),可以先定義一個(gè)變量,將取出的數(shù)據(jù)賦予它,再重復(fù)使用使用PreparedStatement引出 以添加數(shù)據(jù)為例,在很多情況下,具體需要添加的值,是由客戶(hù)自己輸入的,因此,應(yīng)該是一個(gè)個(gè)變量。該情況下,SQL語(yǔ)句的寫(xiě)法就比較麻煩,而且依賴(lài)了變量,比較容易出錯(cuò)PreparedStatement解決了這個(gè)問(wèn)題

使用PreparedStatementPreparedStatement是Statement的子接口,功能與Statement類(lèi)似它在sql語(yǔ)句中使用了?代替了需要插入的參數(shù) 用PreperedStatement的setString(n,參數(shù))方法可以將第n個(gè)?用傳進(jìn)的參數(shù)代替。這樣做增加了程序的可維護(hù)性,也增加了程序的安全性事務(wù)在銀行轉(zhuǎn)賬時(shí),要對(duì)數(shù)據(jù)庫(kù)進(jìn)行兩個(gè)操作,即將一個(gè)賬戶(hù)的錢(qián)減少,將另一個(gè)賬戶(hù)的錢(qián)增多。但是由于操作的先后順序,如果在兩個(gè)操作之間發(fā)生故障,則會(huì)導(dǎo)致數(shù)據(jù)不一致。因此,需要設(shè)計(jì)一個(gè)事務(wù),在兩條語(yǔ)句都被執(zhí)行成功后,數(shù)據(jù)修改才被真正提交(Commit)放入數(shù)據(jù)庫(kù),否則數(shù)據(jù)操作回滾(Rollback)事務(wù)在默認(rèn)情況下,executeUpdate函數(shù)會(huì)在數(shù)據(jù)庫(kù)中提交改變的結(jié)果,此時(shí),可以用Connection來(lái)定義該函數(shù)是否自動(dòng)提交改變結(jié)果,并進(jìn)行事務(wù)的提交或者回滾使用廠(chǎng)商驅(qū)動(dòng)進(jìn)行數(shù)據(jù)庫(kù)連接缺點(diǎn):這類(lèi)驅(qū)動(dòng)程序的彈性較差,由于是數(shù)據(jù)庫(kù)廠(chǎng)商自己提供的專(zhuān)屬驅(qū)動(dòng)程序,往往只適用于自己的數(shù)據(jù)庫(kù)系統(tǒng),甚至只適合某個(gè)版本的數(shù)據(jù)庫(kù)系統(tǒng)。如果后臺(tái)數(shù)據(jù)庫(kù)換了一個(gè)或者版本升級(jí)了,則就有可能需要更換數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序優(yōu)點(diǎn):跨平臺(tái)使用廠(chǎng)商驅(qū)動(dòng)進(jìn)行數(shù)據(jù)庫(kù)連接使用廠(chǎng)商驅(qū)動(dòng),有2個(gè)步驟: 到相應(yīng)的數(shù)據(jù)庫(kù)廠(chǎng)商網(wǎng)站上下載廠(chǎng)商驅(qū)動(dòng),或者從數(shù)據(jù)庫(kù)安裝目錄下找到相應(yīng)的廠(chǎng)商驅(qū)動(dòng)包,拷貝到項(xiàng)目的WEB-INF/lib下。在JDBC代碼中,設(shè)定特定的驅(qū)動(dòng)程序名稱(chēng)和url,

不同的驅(qū)動(dòng)程序和不同的數(shù)據(jù)庫(kù)可以采用不同的驅(qū)動(dòng)名稱(chēng)和url。使用廠(chǎng)商驅(qū)動(dòng)進(jìn)行數(shù)據(jù)庫(kù)連接常見(jiàn)數(shù)據(jù)庫(kù)的驅(qū)動(dòng)程序名稱(chēng)和url如下 MSSQLServer:驅(qū)動(dòng)程序?yàn)椋?com.microsoft.jdbc.sqlserver.SQLServerDriver",url為:"jdbc:microsoft:sqlserver://[IP]:1433;DatabaseName=[DBName];user=[user];password=[password]"使用廠(chǎng)商驅(qū)動(dòng)進(jìn)行數(shù)據(jù)庫(kù)連接 Oracle:驅(qū)動(dòng)程序?yàn)椋?oracle.jdbc.driver.OracleDriver",url為:"jdbc:oracle:thin:@[ip]:1521:[sid]"使用廠(chǎng)商驅(qū)動(dòng)進(jìn)行數(shù)據(jù)庫(kù)連接 MySQL:驅(qū)動(dòng)程序?yàn)椋?com.mysql.jdbc.Driver",

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論