版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
實(shí)驗(yàn)JDBC進(jìn)階一、相關(guān)知識(shí)點(diǎn) 1、JDBC基本概念 2、主從關(guān)系,分頁(yè)查詢二、實(shí)驗(yàn)?zāi)康模?理解分頁(yè)查詢的概念和處理方法三、實(shí)驗(yàn)內(nèi)容:數(shù)據(jù)準(zhǔn)備:用上次實(shí)驗(yàn)中的方法,生成1000個(gè)讀者和圖書(shū);改造讀者模塊,在提取讀者的同時(shí),提取其未歸還的圖書(shū)信息第一步:通過(guò)程序增加一些借閱紀(jì)錄第二步:改造讀者javabean,使之包括借閱的圖書(shū)信息第三步:改造讀者提取方法,同時(shí)提取未歸還圖書(shū);第四步:修改圖書(shū)借閱ui類并進(jìn)行測(cè)試【實(shí)驗(yàn)結(jié)果與分析】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);在圖書(shū)管理系統(tǒng)借幾本書(shū)修改ui類的地方:1.privateObjecttblTitle[]={"讀者證號(hào)","姓名","類別","借閱限額","狀態(tài)","未歸還圖書(shū)信息"};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()+"書(shū)名:"+t2.get(j).getBookname()+ "產(chǎn)商id:"+t2.get(j).getPubid()+"價(jià)格"+t2.get(j).getPrice()+"狀況:"+t2.get(j).getState(); } } tblData[i][5]=imf;測(cè)試:改造讀者管理模塊,將讀者列表頁(yè)面改造成分頁(yè)查詢方式。第一步:第二步:自行設(shè)計(jì)PageData類,用于存放分頁(yè)數(shù)據(jù)第三步:改造ReaderManager類,將其中的查詢讀者方法改造成分頁(yè)查詢。第四步:修改ui類,增加上一頁(yè)、下一頁(yè)按鈕,實(shí)現(xiàn)讀者的分頁(yè)查詢,要求每頁(yè)20人【實(shí)驗(yàn)結(jié)果與分析】PageData類代碼。publicclassPageData{ privateinttotalRecordCount; privateintpageCount; privateintpagesize; privateintpageRecordCount;privateList<BeanReader>beanReader; 用set與get創(chuàng)建方法B. 給出改造后ReaderManager類的方法代碼。publicPageDatasearchReaderPage(Stringkeyword,intreaderTypeId,PageDatapage)throwsBaseException{ //加一個(gè)page類 Connectionconn=null; try{ conn=DBUtil.getConnection(); Stringsql="selectcount(*)fromBeanReaderr,BeanReaderTypertwherer.readerTypeId=rt.readerTypeId"+ "andremoveDateisnull"; //這個(gè)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()); //賦值總頁(yè)面數(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類中的修改部分(注:生成表格的方法需做微調(diào))1.首先增加2個(gè)按鈕即上一頁(yè),和下一頁(yè) 需要修改3個(gè)地方第一個(gè)是: privateButtonprevious=newButton("上一頁(yè)"); privateButtonnext=newButton("下一頁(yè)");如圖:第二個(gè)是: toolBar.add(previous); toolBar.add(next);如圖:第三個(gè)是:增加監(jiān)聽(tīng)器this.previous.addActionListener(this); this.next.addActionListener(this);2.對(duì)page類的一些值進(jìn)行復(fù)制{ page.setPageRecordCount(1);//初始化當(dāng)前的數(shù)是第一頁(yè) page.setPagesize(20);//以20個(gè)記錄為一頁(yè)}注意一定要加中括號(hào)不然會(huì)冒錯(cuò)我也不知道為什么如圖:有些值在ReaderManager類的searchReaderPage方法中已經(jīng)賦值了如圖:3.對(duì)刷新table的方法進(jìn)行修改readers=(newReaderManager()).searchReaderPage(this.edtKeyword.getText(),rtId,page).getBeanReader();注意需要在:BeanReaderType類中加privatePageDatapage;變量順便加下set與get的方法。不然BeanReaderTypert=this.readerTypeMap_name.get(rtname);這句話會(huì)冒錯(cuò)說(shuō)searchReaderPage方法有3個(gè)形參而readerType什么只有2個(gè)形參不行我也不是很懂4.最后在actionPerformed方法中加2個(gè)if當(dāng)按下上一頁(yè)或下一頁(yè)按鈕時(shí)對(duì)當(dāng)前頁(yè)值進(jìn)行修改再刷新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(); }如圖:測(cè)試:第一頁(yè):當(dāng)按下下一頁(yè)后:當(dāng)按下上一頁(yè)后:
公司印章管理制度一、目的公司印章是公司對(duì)內(nèi)對(duì)外行使權(quán)力的標(biāo)志,也是公司名稱的法律體現(xiàn),因此,必須對(duì)印章進(jìn)行規(guī)范化、合理化的嚴(yán)格管理,以保證公司各項(xiàng)業(yè)務(wù)的正常運(yùn)作,由公司指定專人負(fù)責(zé)管理。二、印章的種類公章,是按照政府規(guī)定,由主管部門(mén)批準(zhǔn)刻制的代表公司權(quán)力的印章。專用章,為方便工作專門(mén)刻制的用于某種特定用途的印章,如:合同專用章、財(cái)務(wù)專用章、業(yè)務(wù)專用章、倉(cāng)庫(kù)簽收章等。3、手章(簽名章),是以公司法人代表名字刻
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年甲乙雙方關(guān)于醫(yī)療廢棄物處理設(shè)備塑料管材購(gòu)銷合同
- 二零二五年度個(gè)人店鋪買(mǎi)賣(mài)合同及企業(yè)文化建設(shè)協(xié)議
- 2025年度個(gè)人快遞車(chē)輛租賃運(yùn)輸合同
- 2025年度風(fēng)力發(fā)電項(xiàng)目場(chǎng)地平整與基礎(chǔ)施工合同
- 二零二五年度電梯保養(yǎng)與智慧社區(qū)建設(shè)合同
- 2024年度航空航天領(lǐng)域職業(yè)設(shè)計(jì)師聘用合同3篇
- 2024年電梯設(shè)備維護(hù)保養(yǎng)外包合同
- 2025年鈦酸鋁陶瓷纖維合作協(xié)議書(shū)
- 2024年甲乙雙方關(guān)于環(huán)保項(xiàng)目的合作合同
- 2024年版藝術(shù)品代理銷售協(xié)議書(shū)范本(藝術(shù)市場(chǎng))3篇
- 2023-2024學(xué)年貴州省黔西南布依族苗族自治州貞豐縣三年級(jí)數(shù)學(xué)第一學(xué)期期末經(jīng)典模擬試題含答案
- 社區(qū)服務(wù)中心
- 五金產(chǎn)品檢驗(yàn)作業(yè)指導(dǎo)書(shū)
- 商業(yè)天然氣灶具用氣量明細(xì)
- 體育集體備課記錄
- 錨桿密實(shí)度檢測(cè)
- 跳繩興趣小組活動(dòng)總結(jié)
- 文物保護(hù)項(xiàng)目加固工程監(jiān)理細(xì)則
- 肋骨骨折查房演示
- 五年級(jí)語(yǔ)文備課組工作總結(jié)三篇
- 浙江農(nóng)林大學(xué)土壤肥料學(xué)
評(píng)論
0/150
提交評(píng)論