HOME 首頁(yè)
SERVICE 服務(wù)產(chǎn)品
XINMEITI 新媒體代運(yùn)營(yíng)
CASE 服務(wù)案例
NEWS 熱點(diǎn)資訊
ABOUT 關(guān)于我們
CONTACT 聯(lián)系我們
創(chuàng)意嶺
讓品牌有溫度、有情感
專注品牌策劃15年

    web分頁(yè)實(shí)現(xiàn)的三種方式(web分頁(yè)實(shí)現(xiàn)的三種方式是什么)

    發(fā)布時(shí)間:2023-04-19 05:21:19     稿源: 創(chuàng)意嶺    閱讀: 70        

    大家好!今天讓創(chuàng)意嶺的小編來(lái)大家介紹下關(guān)于web分頁(yè)實(shí)現(xiàn)的三種方式的問(wèn)題,以下是小編對(duì)此問(wèn)題的歸納整理,讓我們一起來(lái)看看吧。

    開(kāi)始之前先推薦一個(gè)非常厲害的Ai人工智能工具,一鍵生成原創(chuàng)文章、方案、文案、工作計(jì)劃、工作報(bào)告、論文、代碼、作文、做題和對(duì)話答疑等等

    只需要輸入關(guān)鍵詞,就能返回你想要的內(nèi)容,越精準(zhǔn),寫出的就越詳細(xì),有微信小程序端、在線網(wǎng)頁(yè)版、PC客戶端

    官網(wǎng):https://ai.de1919.com。

    創(chuàng)意嶺作為行業(yè)內(nèi)優(yōu)秀的企業(yè),服務(wù)客戶遍布全球各地,如需了解SEO相關(guān)業(yè)務(wù)請(qǐng)撥打電話175-8598-2043,或添加微信:1454722008

    本文目錄:

    web分頁(yè)實(shí)現(xiàn)的三種方式(web分頁(yè)實(shí)現(xiàn)的三種方式是什么)

    一、求基于WEB的分頁(yè)技術(shù)與實(shí)現(xiàn)

    記錄總和:COUNT(*)

    總共頁(yè)數(shù)(每頁(yè)15條):COUNT(*) / 15

    第一頁(yè):SELECT * FROM table LIMIT 0, 15

    第二頁(yè):SELECT * FROM table LIMIT 15, 15

    第三頁(yè):SELECT * FROM table LIMIT 30, 15

    第一頁(yè):SELECT * FROM table LIMIT n, 15

    其中,當(dāng)前頁(yè)碼計(jì)算:

    首先接收一個(gè)傳回的頁(yè)碼數(shù) pages

    $_REQUEST['pages'] += 15;

    當(dāng)下一頁(yè)時(shí)每次累加15,上一頁(yè)是每次累減15,當(dāng)操作數(shù)小于0時(shí),可用三元運(yùn)算設(shè)置其為0。防止出現(xiàn)負(fù)數(shù)

    手寫的一個(gè)簡(jiǎn)單的邏輯,希望對(duì)你有所幫助

    二、webjsp中怎么實(shí)現(xiàn)打印的分頁(yè)顯示

    點(diǎn)“文件”——“頁(yè)面設(shè)置”——“工作表”——光標(biāo)放入“頂端標(biāo)題行”后的方框——選中工作表中的共有部分所在 的行(如第一行),如圖:——“確定”即可。

    三、asp.NET分頁(yè)如何實(shí)現(xiàn)?

    Asp.Net分頁(yè)控件實(shí)現(xiàn)分頁(yè)功方法/步驟

    1、首先來(lái)了解Asp.Net分頁(yè)控件——AspNetPager以及控件的屬性。

    CurrentPageIndex//當(dāng)前頁(yè)數(shù)(頁(yè)碼)

    RecordCount //總數(shù)據(jù)條數(shù)

    PageSize //每頁(yè)數(shù)據(jù)條數(shù)

    PageCount //總的頁(yè)數(shù)

    當(dāng)然還有一些特別“人性化”的屬性可以設(shè)置。

    2、接下來(lái)就是給控件屬性賦值就可以了,通過(guò)Sql語(yǔ)句查詢到數(shù)據(jù)庫(kù)中的數(shù)據(jù),

    SqlDataAdapter ada=new SqlDataAdapter(new SqlCommand(Sql語(yǔ)句,連接數(shù)據(jù)庫(kù)對(duì)象);

    DataSet ds=new DataSet();

    ads.Fill(總數(shù)據(jù),開(kāi)始,結(jié)束位置);

    此時(shí)DataSet——ds就是獲得目標(biāo)頁(yè)的數(shù)據(jù),也僅僅是獲得需要的數(shù)據(jù)。

    3、最后需要將查詢到的數(shù)據(jù)顯示到前臺(tái)頁(yè)面,通過(guò)綁定數(shù)據(jù)源控件,常用的Repeater控件就可以循環(huán)顯示數(shù)據(jù)。

    repeater.DataSource=數(shù)據(jù);

    repeater.DataBind();

    Repeater控件還有很多實(shí)用功能,越學(xué)越深,越研越深。

    4、Asp.Net分頁(yè)控件還可以設(shè)置分頁(yè)的首頁(yè)、上一頁(yè)、下一頁(yè)、尾頁(yè)在前臺(tái)顯示的鏈接文本。這里只是提及簡(jiǎn)單功能,深入研究剖析其原理就更得心應(yīng)手了。

    資料來(lái)源:http://news.netshop168.com/cgal/0104249912.html

    四、在JSP中如何實(shí)現(xiàn)分頁(yè)技術(shù)啊?

    title: JSP分頁(yè)技術(shù)實(shí)現(xiàn)

    summary:使用工具類實(shí)現(xiàn)通用分頁(yè)處理

    author: evan_zhao

    email: evan_zhao@hotmail.com

    目前比較廣泛使用的分頁(yè)方式是將查詢結(jié)果緩存在HttpSession或有狀態(tài)bean中,翻頁(yè)的時(shí)候從緩存中取出一頁(yè)數(shù)據(jù)顯示。這種方法有兩個(gè)主要的缺點(diǎn):一是用戶可能看到的是過(guò)期數(shù)據(jù);二是如果數(shù)據(jù)量非常大時(shí)第一次查詢遍歷結(jié)果集會(huì)耗費(fèi)很長(zhǎng)時(shí)間,并且緩存的數(shù)據(jù)也會(huì)占用大量?jī)?nèi)存,效率明顯下降。

    其它常見(jiàn)的方法還有每次翻頁(yè)都查詢一次數(shù)據(jù)庫(kù),從ResultSet中只取出一頁(yè)數(shù)據(jù)(使用rs.last();rs.getRow()獲得總計(jì)錄條數(shù),使用rs.absolute()定位到本頁(yè)起始記錄)。這種方式在某些數(shù)據(jù)庫(kù)(如oracle)的JDBC實(shí)現(xiàn)中差不多也是需要遍歷所有記錄,實(shí)驗(yàn)證明在記錄數(shù)很大時(shí)速度非常慢。

    至于緩存結(jié)果集ResultSet的方法則完全是一種錯(cuò)誤的做法。因?yàn)镽esultSet在Statement或Connection關(guān)閉時(shí)也會(huì)被關(guān)閉,如果要使ResultSet有效勢(shì)必長(zhǎng)時(shí)間占用數(shù)據(jù)庫(kù)連接。

    因此比較好的分頁(yè)做法應(yīng)該是每次翻頁(yè)的時(shí)候只從數(shù)據(jù)庫(kù)里檢索頁(yè)面大小的塊區(qū)的數(shù)據(jù)。這樣雖然每次翻頁(yè)都需要查詢數(shù)據(jù)庫(kù),但查詢出的記錄數(shù)很少,網(wǎng)絡(luò)傳輸數(shù)據(jù)量不大,如果使用連接池更可以略過(guò)最耗時(shí)的建立數(shù)據(jù)庫(kù)連接過(guò)程。而在數(shù)據(jù)庫(kù)端有各種成熟的優(yōu)化技術(shù)用于提高查詢速度,比在應(yīng)用服務(wù)器層做緩存有效多了。

    在oracle數(shù)據(jù)庫(kù)中查詢結(jié)果的行號(hào)使用偽列ROWNUM表示(從1開(kāi)始)。例如select * from employee where rownum<10 返回前10條記錄。但因?yàn)閞ownum是在查詢之后排序之前賦值的,所以查詢employee按birthday排序的第100到120條記錄應(yīng)該這么寫:

    [pre] select * from (

    select my_table.*, rownum as my_rownum from (

    select name, birthday from employee order by birthday

    ) my_table where rownum <120

    ) where my_rownum>=100

    [/pre]

    mySQL可以使用LIMIT子句:

    select name, birthday from employee order by birthday LIMIT 99,20

    DB2有rownumber()函數(shù)用于獲取當(dāng)前行數(shù)。

    SQL Server沒(méi)研究過(guò),可以參考這篇文章:http://www.csdn.net/develop/article/18/18627.shtm

    在Web程序中分頁(yè)會(huì)被頻繁使用,但分頁(yè)的實(shí)現(xiàn)細(xì)節(jié)卻是編程過(guò)程中比較麻煩的事情。大多分頁(yè)顯示的查詢操作都同時(shí)需要處理復(fù)雜的多重查詢條件,sql語(yǔ)句需要?jiǎng)討B(tài)拼接組成,再加上分頁(yè)需要的記錄定位、總記錄條數(shù)查詢以及查詢結(jié)果的遍歷、封裝和顯示,程序會(huì)變得很復(fù)雜并且難以理解。因此需要一些工具類簡(jiǎn)化分頁(yè)代碼,使程序員專注于業(yè)務(wù)邏輯部分。下面是我設(shè)計(jì)的兩個(gè)工具類:

    PagedStatement 封裝了數(shù)據(jù)庫(kù)連接、總記錄數(shù)查詢、分頁(yè)查詢、結(jié)果數(shù)據(jù)封裝和關(guān)閉數(shù)據(jù)庫(kù)連接等操作,并使用了PreparedStatement支持動(dòng)態(tài)設(shè)置參數(shù)。

    RowSetPage 參考PetStore的page by page iterator模式, 設(shè)計(jì)RowSetPage用于封裝查詢結(jié)果(使用OracleCachedRowSet緩存查詢出的一頁(yè)數(shù)據(jù),關(guān)于使用CachedRowSet封裝數(shù)據(jù)庫(kù)查詢結(jié)果請(qǐng)參考JSP頁(yè)面查詢顯示常用模式)以及當(dāng)前頁(yè)碼、總記錄條數(shù)、當(dāng)前記錄數(shù)等信息, 并且可以生成簡(jiǎn)單的HTML分頁(yè)代碼。

    PagedStatement 查詢的結(jié)果封裝成RowsetPage。

    下面是簡(jiǎn)單的使用示例:

    //DAO查詢數(shù)據(jù)部分代碼:

    public RowSetPage getEmployee(String gender, int pageNo) throws Exception{

    String sql="select emp_id, emp_code, user_name, real_name from employee where gender =?";

    //使用Oracle數(shù)據(jù)庫(kù)的分頁(yè)查詢實(shí)現(xiàn),每頁(yè)顯示5條

    PagedStatement pst =new PagedStatementOracleImpl(sql, pageNo, 5);

    pst.setString(1, gender);

    return pst.executeQuery();

    }

    //Servlet處理查詢請(qǐng)求部分代碼:

    int pageNo;

    try{

    //可以通過(guò)參數(shù)pageno獲得用戶選擇的頁(yè)碼

    pageNo = Integer.parseInt(request.getParameter("pageno") );

    }catch(Exception ex){

    //默認(rèn)為第一頁(yè)

    pageNo=1;

    }

    String gender = request.getParameter("gender" );

    request.setAttribute("empPage", myBean.getEmployee(gender, pageNo) );

    //JSP顯示部分代碼

    <%@ page import = "page.RowSetPage"%>

    <script language="javascript">

    function doQuery(){

    form1.actionType.value="doQuery";

    form1.submit();

    }

    </script>

    <form name=form1 method=get>

    <input type=hidden name=actionType>

    性別:

    <input type=text name=gender size=1 value="<%=request.getParameter("gender")%>">

    <input type=button value=" 查詢 " onclick="doQuery()">

    <%

    RowSetPage empPage = (RowSetPage)request.getAttribute("empPage");

    if (empPage == null ) empPage = RowSetPage.EMPTY_PAGE;

    %>

    <table cellspacing="0" width="90%">

    <tr> <td>ID</td> <td>代碼</td> <td>用戶名</td> <td>姓名</td> </tr>

    <%

    javax.sql.RowSet empRS = (javax.sql.RowSet) empPage.getRowSet();

    if (empRS!=null) while (empRS.next() ) {

    %>

    <tr>

    <td><%= empRS.getString("EMP_ID")%></td>

    <td><%= empRS.getString("EMP_CODE")%></td>

    <td><%= empRS.getString("USER_NAME")%></td>

    <td><%= empRS.getString("REAL_NAME")%></td>

    </tr>

    <%

    }// end while

    %>

    <tr>

    <%

    //顯示總頁(yè)數(shù)和當(dāng)前頁(yè)數(shù)(pageno)以及分頁(yè)代碼。

    //此處doQuery為頁(yè)面上提交查詢動(dòng)作的javascript函數(shù)名, pageno為標(biāo)識(shí)當(dāng)前頁(yè)碼的參數(shù)名

    %>

    <td colspan=4><%= empPage .getHTML("doQuery", "pageno")%></td>

    </tr>

    </table>

    </form>

    效果如圖:

    因?yàn)榉猪?yè)顯示一般都會(huì)伴有查詢條件和查詢動(dòng)作,頁(yè)面應(yīng)已經(jīng)有校驗(yàn)查詢條件和提交查詢的javascript方法(如上面的doQuery),所以RowSetPage.getHTML()生成的分頁(yè)代碼在用戶選擇新頁(yè)碼時(shí)直接回調(diào)前面的處理提交查詢的javascript方法。注意在顯示查詢結(jié)果的時(shí)候上次的查詢條件也需要保持,如<input type=text name=gender size=1 value="<%=request.getParameter("gender")%>">。同時(shí)由于頁(yè)碼的參數(shù)名可以指定,因此也支持在同一頁(yè)面中有多個(gè)分頁(yè)區(qū)。

    另一種分頁(yè)代碼實(shí)現(xiàn)是生成每一頁(yè)的URL,將查詢參數(shù)和頁(yè)碼作為QueryString附在URL后面。這種方法的缺陷是在查詢條件比較復(fù)雜時(shí)難以處理,并且需要指定處理查詢動(dòng)作的servlet,可能不適合某些定制的查詢操作。

    如果對(duì)RowSetPage.getHTML()生成的默認(rèn)分頁(yè)代碼不滿意可以編寫自己的分頁(yè)處理代碼,RowSetPage提供了很多getter方法用于獲取相關(guān)信息(如當(dāng)前頁(yè)碼、總頁(yè)數(shù)、 總記錄數(shù)和當(dāng)前記錄數(shù)等)。

    在實(shí)際應(yīng)用中可以將分頁(yè)查詢和顯示做成jsp taglib, 進(jìn)一步簡(jiǎn)化JSP代碼,屏蔽Java Code。

    附:分頁(yè)工具類的源代碼, 有注釋,應(yīng)該很容易理解。

    1.Page.java

    2.RowSetPage.java(RowSetPage繼承Page)

    3.PagedStatement.java

    4.PagedStatementOracleImpl.java(PagedStatementOracleImpl繼承PagedStatement)

    您可以任意使用這些源代碼,但必須保留author evan_zhao@hotmail.com字樣

    ///////////////////////////////////

    //

    // Page.java

    // author: evan_zhao@hotmail.com

    //

    ///////////////////////////////////

    package page;

    import java.util.List;

    import java.util.ArrayList;

    import java.util.Collection;

    import java.util.Collections;

    /**

    * Title: 分頁(yè)對(duì)象<br>

    * Description: 用于包含數(shù)據(jù)及分頁(yè)信息的對(duì)象<br>

    * Page類實(shí)現(xiàn)了用于顯示分頁(yè)信息的基本方法,但未指定所含數(shù)據(jù)的類型,

    * 可根據(jù)需要實(shí)現(xiàn)以特定方式組織數(shù)據(jù)的子類,<br>

    * 如RowSetPage以RowSet封裝數(shù)據(jù),ListPage以List封裝數(shù)據(jù)<br>

    * Copyright: Copyright (c) 2002 <br>

    * @author evan_zhao@hotmail.com <br>

    * @version 1.0

    */

    public class Page implements java.io.Serializable {

    public static final Page EMPTY_PAGE = new Page();

    public static final int DEFAULT_PAGE_SIZE = 20;

    public static final int MAX_PAGE_SIZE = 9999;

    private int myPageSize = DEFAULT_PAGE_SIZE;

    private int start;

    private int avaCount,totalSize;

    private Object data;

    private int currentPageno;

    private int totalPageCount;

    /**

    * 默認(rèn)構(gòu)造方法,只構(gòu)造空頁(yè)

    */

    protected Page(){

    this.init(0,0,0,DEFAULT_PAGE_SIZE,new Object());

    }

    /**

    * 分頁(yè)數(shù)據(jù)初始方法,由子類調(diào)用

    * @param start 本頁(yè)數(shù)據(jù)在數(shù)據(jù)庫(kù)中的起始位置

    * @param avaCount 本頁(yè)包含的數(shù)據(jù)條數(shù)

    * @param totalSize 數(shù)據(jù)庫(kù)中總記錄條數(shù)

    * @param pageSize 本頁(yè)容量

    * @param data 本頁(yè)包含的數(shù)據(jù)

    */

    protected void init(int start, int avaCount, int totalSize, int pageSize, Object data){

    this.avaCount =avaCount;

    this.myPageSize = pageSize;

    this.start = start;

    this.totalSize = totalSize;

    this.data=data;

    //System.out.println("avaCount:"+avaCount);

    //System.out.println("totalSize:"+totalSize);

    if (avaCount>totalSize) {

    //throw new RuntimeException("記錄條數(shù)大于總條數(shù)?!");

    }

    this.currentPageno = (start -1)/pageSize +1;

    this.totalPageCount = (totalSize + pageSize -1) / pageSize;

    if (totalSize==0 && avaCount==0){

    this.currentPageno = 1;

    this.totalPageCount = 1;

    }

    //System.out.println("Start Index to Page No: " + start + "-" + currentPageno);

    }

    public Object getData(){

    return this.data;

    }

    /**

    * 取本頁(yè)數(shù)據(jù)容量(本頁(yè)能包含的記錄數(shù))

    * @return 本頁(yè)能包含的記錄數(shù)

    */

    public int getPageSize(){

    return this.myPageSize;

    }

    /**

    * 是否有下一頁(yè)

    * @return 是否有下一頁(yè)

    */

    public boolean hasNextPage() {

    /*

    if (avaCount==0 && totalSize==0){

    return false;

    }

    return (start + avaCount -1) < totalSize;

    */

    return (this.getCurrentPageNo()<this.getTotalPageCount());

    }

    /**

    * 是否有上一頁(yè)

    * @return 是否有上一頁(yè)

    */

    public boolean hasPreviousPage() {

    /*

    return start > 1;

    */

    return (this.getCurrentPageNo()>1);

    }

    /**

    * 獲取當(dāng)前頁(yè)第一條數(shù)據(jù)在數(shù)據(jù)庫(kù)中的位置

    * @return

    */

    public int getStart(){

    return start;

    }

    /**

    * 獲取當(dāng)前頁(yè)最后一條數(shù)據(jù)在數(shù)據(jù)庫(kù)中的位置

    * @return

    */

    public int getEnd(){

    int end = this.getStart() + this.getSize() -1;

    if (end<0) {

    end = 0;

    }

    return end;

    }

    /**

    * 獲取上一頁(yè)第一條數(shù)據(jù)在數(shù)據(jù)庫(kù)中的位置

    * @return 記錄對(duì)應(yīng)的rownum

    */

    public int getStartOfPreviousPage() {

    return Math.max(start-myPageSize, 1);

    }

    /**

    * 獲取下一頁(yè)第一條數(shù)據(jù)在數(shù)據(jù)庫(kù)中的位置

    * @return 記錄對(duì)應(yīng)的rownum

    */

    public int getStartOfNextPage() {

    return start + avaCount;

    }

    /**

    * 獲取任一頁(yè)第一條數(shù)據(jù)在數(shù)據(jù)庫(kù)中的位置,每頁(yè)條數(shù)使用默認(rèn)值

    * @param pageNo 頁(yè)號(hào)

    * @return 記錄對(duì)應(yīng)的rownum

    */

    public static int getStartOfAnyPage(int pageNo){

    return getStartOfAnyPage(pageNo, DEFAULT_PAGE_SIZE);

    }

    /**

    * 獲取任一頁(yè)第一條數(shù)據(jù)在數(shù)據(jù)庫(kù)中的位置

    * @param pageNo 頁(yè)號(hào)

    * @param pageSize 每頁(yè)包含的記錄數(shù)

    * @return 記錄對(duì)應(yīng)的rownum

    */

    public static int getStartOfAnyPage(int pageNo, int pageSize){

    int startIndex = (pageNo-1) * pageSize + 1;

    if ( startIndex < 1) startIndex = 1;

    //System.out.println("Page No to Start Index: " + pageNo + "-" + startIndex);

    return startIndex;

    }

    /**

    * 取本頁(yè)包含的記錄數(shù)

    * @return 本頁(yè)包含的記錄數(shù)

    */

    public int getSize() {

    return avaCount;

    }

    /**

    * 取數(shù)據(jù)庫(kù)中包含的總記錄數(shù)

    * @return 數(shù)據(jù)庫(kù)中包含的總記錄數(shù)

    */

    public int getTotalSize() {

    return this.totalSize;

    }

    /**

    * 取當(dāng)前頁(yè)碼

    * @return 當(dāng)前頁(yè)碼

    */

    public int getCurrentPageNo(){

    return this.currentPageno;

    }

    /**

    * 取總頁(yè)碼

    * @return 總頁(yè)碼

    */

    public int getTotalPageCount(){

    return this.totalPageCount;

    }

    /**

    *

    * @param queryJSFunctionName 實(shí)現(xiàn)分頁(yè)的JS腳本名字,頁(yè)碼變動(dòng)時(shí)會(huì)自動(dòng)回調(diào)該方法

    * @param pageNoParamName 頁(yè)碼參數(shù)名稱

    * @return

    */

    public String getHTML(String queryJSFunctionName, String pageNoParamName){

    if (getTotalPageCount()<1){

    return "<input type='hidden' name='"+pageNoParamName+"' value='1' >";

    }

    if (queryJSFunctionName == null || queryJSFunctionName.trim().length()<1) {

    queryJSFunctionName = "gotoPage";

    }

    if (pageNoParamName == null || pageNoParamName.trim().length()<1){

    pageNoParamName = "pageno";

    }

    String gotoPage = "_"+queryJSFunctionName;

    StringBuffer html = new StringBuffer("\n");

    html.append("<script language=\"Javascript1.2\">\n")

    .append("function ").append(gotoPage).append("(pageNo){ \n")

    .append( " var curPage=1; \n")

    .append( " try{ curPage = document.all[\"")

    .append(pageNoParamName).append("\"].value; \n")

    .append( " document.all[\"").append(pageNoParamName)

    .append("\"].value = pageNo; \n")

    .append( " ").append(queryJSFunctionName).append("(pageNo); \n")

    .append( " return true; \n")

    .append( " }catch(e){ \n")

    // .append( " try{ \n")

    // .append( " document.forms[0].submit(); \n")

    // .append( " }catch(e){ \n")

    .append( " alert('尚未定義查詢方法:function ")

    .append(queryJSFunctionName).append("()'); \n")

    .append( " document.all[\"").append(pageNoParamName)

    .append("\"].value = curPage; \n")

    .append( " return false; \n")

    // .append( " } \n")

    .append( " } \n")

    .append( "}")

    .append( "</script> \n")

    .append( "");

    html.append( "<table border=0 cellspacing=0 cellpadding=0 align=center width=80%> \n")

    .append( " <tr> \n")

    .append( " <td align=left><br> \n");

    html.append( " 共" ).append( getTotalPageCount() ).append( "頁(yè)")

    .append( " [") .append(getStart()).append("..").append(getEnd())

    .append("/").append(this.getTotalSize()).append("] \n")

    .append( " </td> \n")

    .append( " <td align=right> \n");

    if (hasPreviousPage()){

    html.append( "[<a href='javascript:").append(gotoPage)

    .append("(") .append(getCurrentPageNo()-1)

    .append( ")'>上一頁(yè)</a>] \n");

    }

    html.append( " 第")

    .append( " <select name='")

    .append(pageNoParamName).append("' onChange='javascript:")

    .append(gotoPage).append("(this.value)'>\n");

    String selected = "selected";

    for(int i=1;i<=getTotalPageCount();i++){

    if( i == getCurrentPageNo() )

    selected = "selected";

    else selected = "";

    html.append( " <option value='").append(i).append("' ")

    .append(selected).append(">").append(i).append("</option> \n");

    }

    if (getCurrentPageNo()>getTotalPageCount()){

    html.append( " <option value='").append(getCurrentPageNo())

    .append("' selected>").append(getCurrentPageNo())

    .append("</option> \n");

    }

    html.append( " </select>頁(yè) \n");

    if (hasNextPage()){

    html.append( " [<a href='javascript:").append(gotoPage)

    .append("(").append((getCurrentPageNo()+1))

    .append( ")'>下一頁(yè)</a>] \n");

    }

    html.append( "</td></tr></table> \n");

    return html.toString();

    }

    }

    ///////////////////////////////////

    //

    // RowSetPage.java

    // author: evan_zhao@hotmail.com

    //

    ///////////////////////////////////

    package page;

    import javax.sql.RowSet;

    /**

    * <p>Title: RowSetPage</p>

    * <p>Description: 使用RowSet封裝數(shù)據(jù)的分頁(yè)對(duì)象</p>

    * <p>Copyright: Copyright (c) 2003</p>

    * @author evan_zhao@hotmail.com

    * @version 1.0

    */

    public class RowSetPage extends Page {

    private javax.sql.RowSet rs;

    /**

    *空頁(yè)

    */

    public static final RowSetPage EMPTY_PAGE = new RowSetPage();

    /**

    *默認(rèn)構(gòu)造方法,創(chuàng)建空頁(yè)

    */

    public RowSetPage(){

    this(null, 0,0);

    }

    /**

    *構(gòu)造分頁(yè)對(duì)象

    *@param crs 包含一頁(yè)數(shù)據(jù)的OracleCachedRowSet

    *@param start 該頁(yè)數(shù)據(jù)在數(shù)據(jù)庫(kù)中的起始位置

    *@param totalSize 數(shù)據(jù)庫(kù)中包含的記錄總數(shù)

    */

    public RowSetPage(RowSet crs, int start, int totalSize) {

    this(crs,start,totalSize,Page.DEFAULT_PAGE_SIZE);

    }

    /**

    *構(gòu)造分頁(yè)對(duì)象

    *@param crs 包含一頁(yè)數(shù)據(jù)的OracleCachedRowSet

    *@param start 該頁(yè)數(shù)據(jù)在數(shù)據(jù)庫(kù)中的起始位置

    *@param totalSize 數(shù)據(jù)庫(kù)中包含的記錄總數(shù)

    *@pageSize 本頁(yè)能容納的記錄數(shù)

    */

    public RowSetPage(RowSet crs, int start, int totalSize, int pageSize) {

    try{

    int avaCount=0;

    if (crs!=null) {

    crs.beforeFirst();

    if (crs.next()){

    crs.last();

    avaCount = crs.getRow();

    }

    crs.beforeFirst();

    }

    rs = crs;

    super.init(start,avaCount,totalSize,pageSize,rs);

    }catch(java.sql.SQLException sqle){

    throw new RuntimeException(sqle.toString());

    }

    }

    /**

    *取分頁(yè)對(duì)象中的記錄數(shù)據(jù)

    */

    public javax.sql.RowSet getRowSet(){

    return rs;

    }

    }

    ///////////////////////////////////

    //

    // PagedStatement.java

    // author: evan_zhao@hotmail.com

    //

    ///////////////////////////////////

    package page;

    import foo.DBUtil;

    import java.math.BigDecimal;

    import java.util.List;

    import java.util.Iterator;

    import java.util.Collections;

    import java.sql.Connection;

    import java.sql.SQLException;

    import java.sql.ResultSet;

    import java.sql.Statement;

    import java.sql.PreparedStatement;

    import java.sql.Timestamp;

    import javax.sql.RowSet;

    /**

    * <p>Title: 分頁(yè)查詢</p>

    * <p>Description: 根據(jù)查詢語(yǔ)句和頁(yè)碼查詢出當(dāng)頁(yè)數(shù)據(jù)</p>

    * <p>Copyright: Copyright (c) 2002</p>

    * @author evan_zhao@hotmail.com

    * @version 1.0

    */

    public abstract class PagedStatement {

    public final static int MAX_PAGE_SIZE = Page.MAX_PAGE_SIZE;

    protected String countSQL, querySQL;

    protected int pageNo,pageSize,startIndex,totalCount;

    protected javax.sql.RowSet rowSet;

    protected RowSetPage rowSetPage;

    private List boundParams;

    /**

    * 構(gòu)造一查詢出所有數(shù)據(jù)的PageStatement

    * @param sql query sql

    */

    public PagedStatement(String sql){

    this(sql,1,MAX_PAGE_SIZE);

    }

    /**

    * 構(gòu)造一查詢出當(dāng)頁(yè)數(shù)據(jù)的PageStatement

    * @param sql query sql

    * @param pageNo 頁(yè)碼

    */

    public PagedStatement(String sql, int pageNo){

    this(sql, pageNo, Page.DEFAULT_PAGE_SIZE);

    }

    /**

    * 構(gòu)造一查詢出當(dāng)頁(yè)數(shù)據(jù)的PageStatement,并指定每頁(yè)顯示記錄條數(shù)

    * @param sql query sql

    * @param pageNo 頁(yè)碼

    * @param pageSize 每頁(yè)容量

    */

    public PagedStatement(String sql, int pageNo, int pageSize){

    this.pageNo = pageNo;

    this.pageSize = pageSize;

    this.startIndex = Page.getStartOfAnyPage(pageNo, pageSize);

    this.boundParams = Collections.synchronizedList(new java.util.LinkedList());

    this.countSQL = "select count(*) from ( " + sql +") ";

    this.querySQL = intiQuerySQL(sql, this.startIndex, pageSize);

    }

    /**

    *生成查詢一頁(yè)數(shù)據(jù)的sql語(yǔ)句

    *@param sql 原查詢語(yǔ)句

    *@startIndex 開(kāi)始記錄位置

    *@size 需要獲取的記錄數(shù)

    */

    protected abstract String intiQuerySQL(String sql, int startIndex, int size);

    /**

    *使用給出的對(duì)象設(shè)置指定參數(shù)的值

    *@param index 第一個(gè)參數(shù)為1,第二個(gè)為2

    以上就是關(guān)于web分頁(yè)實(shí)現(xiàn)的三種方式相關(guān)問(wèn)題的回答。希望能幫到你,如有更多相關(guān)問(wèn)題,您也可以聯(lián)系我們的客服進(jìn)行咨詢,客服也會(huì)為您講解更多精彩的知識(shí)和內(nèi)容。


    推薦閱讀:

    wechat國(guó)際版iOS賬號(hào)(國(guó)際版微信賬號(hào))

    web服務(wù)器工作原理(web服務(wù)器工作原理圖)

    helpwechatcom

    短視頻創(chuàng)業(yè)怎么賺錢(短視頻創(chuàng)業(yè)賺錢嗎)

    快手話費(fèi)充值怎么退款(快手話費(fèi)充值怎么退款流程)