




版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
實驗JDBC進階一、相關知識點 1、JDBC基本概念 2、主從關系,分頁查詢二、實驗目的: 理解分頁查詢的概念和處理方法三、實驗內(nèi)容:數(shù)據(jù)準備:用上次實驗中的方法,生成1000個讀者和圖書;改造讀者模塊,在提取讀者的同時,提取其未歸還的圖書信息第一步:通過程序增加一些借閱紀錄第二步:改造讀者javabean,使之包括借閱的圖書信息第三步:改造讀者提取方法,同時提取未歸還圖書;第四步:修改圖書借閱ui類并進行測試【實驗結果與分析】javabean類代碼。privateList<BeanBook>beanBook; publicList<BeanBook>getBeanBook(){ returnbeanBook; } publicvoidsetBeanBook(List<BeanBook>beanBook){ this.beanBook=beanBook; }給出改造后ReaderManager類的方法代碼。List<BeanBook>result1=newArrayList<BeanBook>(); Stringsql1="selecta.barcode,a.bookname,a.pubid,a.price,a.statefrombeanbooka,beanbooklendrecordbwhereb.readerid='"+rs.getString(1)+"'andb.bookBarcode=a.barcodeandb.returnDateisnull"; java.sql.PreparedStatementpst1=conn.prepareStatement(sql1); java.sql.ResultSetrs1=pst1.executeQuery(); while(rs1.next()) { BeanBookb=newBeanBook(); b.setBarcode(rs1.getString(1)); b.setBookname(rs1.getString(2)); b.setPubid(rs1.getString(3)); b.setPrice(rs1.getFloat(4)); b.setState(rs1.getString(5)); result1.add(b); } r.setBeanBook(result1); result.add(r);在圖書管理系統(tǒng)借幾本書修改ui類的地方:1.privateObjecttblTitle[]={"讀者證號","姓名","類別","借閱限額","狀態(tài)","未歸還圖書信息"};2.tblData=newObject[readers.size()][6];3.List<BeanBook>t2=readers.get(i).getBeanBook(); Stringimf=""; if(t2!=null) { for(intj=0;j<t2.size();j++) { imf=imf+"條形碼:"+t2.get(j).getBarcode()+"書名:"+t2.get(j).getBookname()+ "產(chǎn)商id:"+t2.get(j).getPubid()+"價格"+t2.get(j).getPrice()+"狀況:"+t2.get(j).getState(); } } tblData[i][5]=imf;測試:改造讀者管理模塊,將讀者列表頁面改造成分頁查詢方式。第一步:第二步:自行設計PageData類,用于存放分頁數(shù)據(jù)第三步:改造ReaderManager類,將其中的查詢讀者方法改造成分頁查詢。第四步:修改ui類,增加上一頁、下一頁按鈕,實現(xiàn)讀者的分頁查詢,要求每頁20人【實驗結果與分析】PageData類代碼。publicclassPageData{ privateinttotalRecordCount; privateintpageCount; privateintpagesize; privateintpageRecordCount;privateList<BeanReader>beanReader; 用set與get創(chuàng)建方法B. 給出改造后ReaderManager類的方法代碼。publicPageDatasearchReaderPage(Stringkeyword,intreaderTypeId,PageDatapage)throwsBaseException{ //加一個page類 Connectionconn=null; try{ conn=DBUtil.getConnection(); Stringsql="selectcount(*)fromBeanReaderr,BeanReaderTypertwherer.readerTypeId=rt.readerTypeId"+ "andremoveDateisnull"; //這個sql是為了記錄總記錄數(shù) java.sql.PreparedStatementpst=conn.prepareStatement(sql); java.sql.ResultSetrs=pst.executeQuery(); if(rs.next()) page.setTotalRecordCount(rs.getInt(1)); //賦值總記錄數(shù) page.setPageCount(page.getTotalRecordCount()/page.getPagesize()); //賦值總頁面數(shù) List<BeanReader>result1=newArrayList<BeanReader>(); Stringsql1="selecttop"+page.getPagesize()+"readerid,readerName,r.readerTypeId,r.lendBookLimitted,createDate,creatorUserId,stopDate,stopUserId,rt.readerTypeName"+ "fromBeanReaderr,BeanReaderTypertwherer.readerTypeId=rt.readerTypeId"+ "andremoveDateisnull"; if(page.getPageRecordCount()!=1) sql1+="andreaderidnotin(selecttop"+(page.getPageRecordCount()-1)*(page.getPagesize())+"readeridfromBeanReaderwhereremoveDateisnull)"; if(readerTypeId>0)sql1+="andr.readerTypeId="+readerTypeId; if(keyword!=null&&!"".equals(keyword)) sql1+="and(readeridlike?orreaderNamelike?)"; sql1+="orderbyreaderid"; java.sql.PreparedStatementpst1=conn.prepareStatement(sql1); if(keyword!=null&&!"".equals(keyword)){ pst1.setString(1,"%"+keyword+"%"); pst1.setString(2,"%"+keyword+"%"); } java.sql.ResultSetrs1=pst1.executeQuery(); while(rs1.next()){ BeanReaderr=newBeanReader(); r.setReaderid(rs1.getString(1)); r.setReaderName(rs1.getString(2)); r.setReaderTypeId(rs1.getInt(3)); r.setLendBookLimitted(rs1.getInt(4)); r.setCreateDate(rs1.getDate(5)); r.setCreatorUserId(rs1.getString(6)); r.setStopDate(rs1.getDate(7)); r.setStopUserId(rs1.getString(8)); r.setReaderTypeName(rs1.getString(9)); List<BeanBook>result2=newArrayList<BeanBook>(); Stringsql2="selecta.barcode,a.bookname,a.pubid,a.price,a.statefrombeanbooka,beanbooklendrecordbwhereb.readerid='"+rs1.getString(1)+"'andb.bookBarcode=a.barcodeandb.returnDateisnull"; java.sql.PreparedStatementpst2=conn.prepareStatement(sql2); java.sql.ResultSetrs2=pst2.executeQuery(); while(rs2.next()) { BeanBookb=newBeanBook(); b.setBarcode(rs2.getString(1)); b.setBookname(rs2.getString(2)); b.setPubid(rs2.getString(3)); b.setPrice(rs2.getFloat(4)); b.setState(rs2.getString(5)); result2.add(b); } r.setBeanBook(result2); result1.add(r); } page.setBeanReader(result1); }catch(SQLExceptione){ e.printStackTrace(); thrownewDbException(e); } finally{ if(conn!=null) try{ conn.close(); }catch(SQLExceptione){ //TODOAuto-generatedcatchblock e.printStackTrace(); } } returnpage; } 給出ui類中的修改部分(注:生成表格的方法需做微調)1.首先增加2個按鈕即上一頁,和下一頁 需要修改3個地方第一個是: privateButtonprevious=newButton("上一頁"); privateButtonnext=newButton("下一頁");如圖:第二個是: toolBar.add(previous); toolBar.add(next);如圖:第三個是:增加監(jiān)聽器this.previous.addActionListener(this); this.next.addActionListener(this);2.對page類的一些值進行復制{ page.setPageRecordCount(1);//初始化當前的數(shù)是第一頁 page.setPagesize(20);//以20個記錄為一頁}注意一定要加中括號不然會冒錯我也不知道為什么如圖:有些值在ReaderManager類的searchReaderPage方法中已經(jīng)賦值了如圖:3.對刷新table的方法進行修改readers=(newReaderManager()).searchReaderPage(this.edtKeyword.getText(),rtId,page).getBeanReader();注意需要在:BeanReaderType類中加privatePageDatapage;變量順便加下set與get的方法。不然BeanReaderTypert=this.readerTypeMap_name.get(rtname);這句話會冒錯說searchReaderPage方法有3個形參而readerType什么只有2個形參不行我也不是很懂4.最后在actionPerformed方法中加2個if當按下上一頁或下一頁按鈕時對當前頁值進行修改再刷新tableelseif(e.getSource()==this.previous){ if(page.getPageRecordCount()>1){ page.setPageRecordCount(page.getPageRecordCount()-1); this.reloadTable(); } } elseif(e.getSource()==this.next){ if(page.getPageRecordCount()<page.getTotalRecordCount()){ page.setPageRecordCount(page.getPageRecordCount()+1); this.reloadTable(); }如圖:測試:第一頁:當按下下一頁后:當按下上一頁后:
公司印章管理制度一、目的公司印章是公司對內(nèi)對外行使權力的標志,也是公司名稱的法律體現(xiàn),因此,必須對印章進行規(guī)范化、合理化的嚴格管理,以保證公司各項業(yè)務的正常運作,由公司指定專人負責管理。二、印章的種類公章,是按照政府規(guī)定,由主管部門批準刻制的代表公司權力的印章。專用章,為方便工作專門刻制的用于某種特定用途的印章,如:合同專用章、財務專用章、業(yè)務專用章、倉庫簽收章等。3、手章(簽名章),是以公司法人代表名字刻
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 運動裝備定制銷售合同
- 2023-2024學年高中信息技術選修2(浙教版2019)-網(wǎng)絡基礎-教學設計-2.1-網(wǎng)絡拓撲結構
- 13-2《上圖書館》 教學設計 2024-2025學年統(tǒng)編版高中語文必修上冊
- Lesson 1 Nice to meet you. Period 1(教學設計)-2024-2025學年接力版英語四年級上冊
- 11 四通八達的交通(教學設計)-2023-2024學年道德與法治三年級下冊統(tǒng)編版
- 2 點亮小燈泡 教學設計-2023-2024學年科學四年級下冊教科版
- 2025年激光隧道斷面測量系統(tǒng)項目發(fā)展計劃
- 餐車訂購合同范本
- 婚禮公司合同范本
- 17要是你在野外迷了路 教學設計-2023-2024學年語文二年級下冊統(tǒng)編版
- 中國垂直起降場地建設行業(yè)市場現(xiàn)狀及投資態(tài)勢分析報告(智研咨詢)
- 倉庫租賃、物資倉儲保管服務投標方案(技術方案)
- 2024年內(nèi)蒙古中考語文試卷五套合卷附答案
- 矯形器裝配工(四級)職業(yè)技能鑒定考試題庫(含答案)
- 2025年全國100所名校高三3月起點調研考試-數(shù)學試題含解析
- 小學語文教學評一致性論文
- SF-36生活質量調查表(SF-36-含評分細則)
- 術后鎮(zhèn)痛泵的使用與護理
- GB 19522-2024車輛駕駛人員血液、呼氣酒精含量閾值與檢驗
- 2024年成都新都投資集團有限公司招聘筆試沖刺題(帶答案解析)
- 危險預知訓練表(KYT)
評論
0/150
提交評論