JSP實驗報告使用JDBC實現(xiàn)數(shù)據(jù)庫連接_第1頁
JSP實驗報告使用JDBC實現(xiàn)數(shù)據(jù)庫連接_第2頁
JSP實驗報告使用JDBC實現(xiàn)數(shù)據(jù)庫連接_第3頁
JSP實驗報告使用JDBC實現(xiàn)數(shù)據(jù)庫連接_第4頁
JSP實驗報告使用JDBC實現(xiàn)數(shù)據(jù)庫連接_第5頁
已閱讀5頁,還剩8頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、廣州中醫(yī)藥大學醫(yī)學信息工程學院實 驗 報 告課程名稱:網(wǎng)絡數(shù)據(jù)庫編程專業(yè)班級:計算機科學與技術(shù)(2010)級學生學號:2010081126學生姓名:呂呂實驗名稱:實驗成績:課程類別:必修 限選 公選 其它實驗三 使用jdbc實現(xiàn)數(shù)據(jù)庫連接實驗類型:應用性實驗 實驗日期: 2013.03.20 實驗目的要求通過教學,使學生掌握使用jdbc連接到數(shù)據(jù)庫的方法(如通過jdbc-odbc橋或pure java driver),能使用網(wǎng)頁表單實現(xiàn)網(wǎng)頁與數(shù)據(jù)庫的交互。實驗內(nèi)容及步驟1、 在數(shù)據(jù)庫sql server中創(chuàng)建一個數(shù)據(jù)庫jdbctest,并創(chuàng)建表student_info,并設定字段,輸入內(nèi)容。2

2、、 使用jdbc-odbc實現(xiàn)數(shù)據(jù)庫連接a) 打開“控制面板”的“管理工具” 的“數(shù)據(jù)源 (odbc)”b) 建立數(shù)據(jù)源c) 選“系統(tǒng)數(shù)據(jù)源”,連接sql server數(shù)據(jù)庫d) 測試是否連接成功e) 通過以下類class、drivermanager、connection(連接數(shù)據(jù)庫用到的類),及statement、resultset(訪問數(shù)據(jù)庫用到的類)編寫代碼實現(xiàn)表student_info數(shù)據(jù)的查詢。f) 查詢結(jié)果在頁面中顯示。3、 使用pure java driver實現(xiàn)數(shù)據(jù)庫連接(本題可以做可以不做)a) 安裝sql-jdbc,如裝在d盤b) 設置環(huán)境變量classpath,添加d:s

3、qljdbcmsbase.jar; d:sqljdbcmsutil.jar; d:sqljdbcmssqlserver.jar;c) 設sql server數(shù)據(jù)庫用windows和數(shù)據(jù)庫混合身分驗證的方式。d) 通過以下類class、drivermanager、connection(連接數(shù)據(jù)庫用到的類),及statement、resultset(訪問數(shù)據(jù)庫用到的類)編寫代碼實現(xiàn)表student_info數(shù)據(jù)的查詢。e) 查詢結(jié)果在頁面中顯示。4、 通過表單傳遞數(shù)據(jù),實現(xiàn)數(shù)據(jù)庫的插入、刪除與更新操作,并顯示插入結(jié)果。5、 熟悉jsp中各種常用的內(nèi)建對象如request對象、session對象、a

4、pplication對象的使用。6、 熟悉各種表單的處理的方法:如選擇按鈕的使用、多選方塊的使用、群組檢查的使用、隱藏欄位的使用、在客戶端進行數(shù)據(jù)檢查7、 試利用上述知識實現(xiàn)一個留言板系統(tǒng)。以下需要同學們貼上第7題經(jīng)調(diào)試好代碼:數(shù)據(jù)庫對應的表1答:本人在mysql數(shù)據(jù)庫中建立了數(shù)據(jù)庫jsp-experiment,再建立兩個表,一為表studentinfo,存放學生的基本信息,另一個表為message,用來存放學生的留言記錄,截圖如下:數(shù)據(jù)庫:jsp-experiment表studentinfo:表message:留言板實現(xiàn)步驟和代碼:1.用戶登錄用到userlogin.jsp文件,代碼為:登錄

5、用戶登錄用戶名: 密 碼: !- 界面截圖:2.連接數(shù)據(jù)庫進行用戶合法性檢查,用到verifylogin.jsp文件,若用戶存在,則跳轉(zhuǎn)到留言界面,代碼如下:登錄!-3.進入到留言界面后,進行留言,用到messageboard.jsp文件,代碼為:function clear() document.getelementbyid(messagecontent).value=; 留言板body color: #0033ff;登錄成功用戶信息:姓名: 學號:請輸入您的留言:!-/-界面截圖:4.留言成功后,將顯示留言的記錄,用到insertmessage1.jsp文件,代碼為: database%

6、/獲取用戶名 string susername =(string)request.getsession().getattribute(sessionname); /獲取密碼 string spasswd =(string)request.getsession().getattribute(sessionpwd); /獲取留言 string message= request.getparameter (messagecontent); string url=jdbc:mysql:/localhost/jsp-experiment; string user =root;/這里替換成你自已的數(shù)據(jù)庫用

7、戶名 string password = 123;/這里替換成你自已的數(shù)據(jù)庫用戶密碼 /string sqlstr = select * from message where studentno=2010081126; /string sqlstr = select * from studentinfo; string sql = insert into message(studentno,messagetime,message) values (+spasswd+,now(),+message+); string sqlstr=select * from message where stud

8、entno=+spasswd+; try /這里的異常處理語句是必需的.否則不能通過編譯! class.forname(com.mysql.jdbc.driver); /out.println(com.mysql.jdbc.driver類實例化成功! ); /connection con = drivermanager.getconnection(url); connection con = drivermanager.getconnection(url,user,password); statement st = con.createstatement(); st.execute(sql);

9、 resultset rs = st.executequery(sqlstr); out.println(添加留言成功!); out.println(); out.println(您的留言記錄為:); out.println(); out.println(); /out.println(學號留言時間留言內(nèi)容); while (rs.next() string col1 = rs.getstring(studentno); string col2 = rs.getstring(messagetime); string col3= rs.getstring(message); /打印所顯示的數(shù)據(jù)

10、out.println(+col1+col2+col3+); out.println(); rs.close(); st.close(); con.close(); catch(exception err) err.printstacktrace(); out.print(); out.println(connecting to the database is error); %界面截圖:提交后:(以下為理論知識題)8、 jdbc的全稱是什么,在java的哪個包下?答:全稱為java data base connectivity,java數(shù)據(jù)庫連接,在java.sql里。9、jdbc連接數(shù)據(jù)庫

11、用到的類有哪些?答: 1. class/指定數(shù)據(jù)庫驅(qū)動程序2. drivermanager/驅(qū)動程序管理3. connection/數(shù)據(jù)庫連接10、比較jdbc數(shù)據(jù)庫連接的jdbc-odbc橋及pure java driver方式的優(yōu)缺點答;(1)jdbc-odbc bridge plus odbc driver優(yōu)點:可以沿用舊系統(tǒng)的設置缺點:設置odbc連接繁瑣,在jdbc與odbc中數(shù)據(jù)傳遞及轉(zhuǎn)換上需要一定的時間(2)pure java driver for database middleware優(yōu)點:不用在用戶端做任何的設置或安裝一些函數(shù)庫,只需連接中間層服務器缺點:連接受中間層服務器影

12、響11、statement與preparedstatement的作用與區(qū)別?寫一個程序?qū)嵗绾斡胮reparedstatement實現(xiàn)批處理? (將100條記錄插入預先設定好的數(shù)據(jù)庫中)答:1. preparedstatement是預編譯的,對于批量處理可以大大提高效率. 也叫jdbc存儲過程;2. 使用 statement 對象。在對數(shù)據(jù)庫只執(zhí)行一次性存取的時侯,用 statement 對象進行處理。preparedstatement 對象的開銷比statement大,對于一次性操作并不會帶來額外的好處;3. statement每次執(zhí)行sql語句,相關(guān)數(shù)據(jù)庫都要執(zhí)行sql語句的編譯,prep

13、aredstatement是預編譯得, preparedstatement支持批處理。程序?qū)嵗簆ublic void exec3(connection conn) try conn.setautocommit(false); long begintime = system.currenttimemillis(); preparedstatement pst = conn.preparestatement(insert into t1(id) values(?); for(int i=1;i=100;i+) pst.setint(1, i); pst.addbatch(); if(i%50=0

14、) pst.executebatch(); mit(); pst.clearbatch(); pst.executebatch(); long endtime = system.currenttimemillis(); system.out.println(pst+batch用時:+(endtime-begintime)+毫秒); pst.close(); conn.close(); catch (sqlexception e) e.printstacktrace(); 12、statement接口提供了三種執(zhí)行sql語句的方法,它們分別是什么? 答:查詢方法:executequery;更新方法:execut

溫馨提示

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

評論

0/150

提交評論