分頁顯示問題的解決方案(jsp,sqlserver,mysql,oracle)

來源:互聯網
上載者:User
js|mysql|oracle|server|sqlserver|分頁|解決|問題|顯示   
轉貼請註明本貼地址以及作者:與莫紮特相遇(bobrow)
同學在做jsp實現一個網上交易平台時一碰到了這個問題,我想這個問題一定具有代表性,因為分頁顯示技術要用到的地方確實很多。為了減少初學者在這方面花的時間,我在一些資料的基礎上,總結了分頁顯示的方法。
方法一:
最常用的方法,就是使用直接中資料庫中獲得所有行的結果集,然後通過定位標誌,使用next()。
範例程式碼(資料庫使用mysql):
//變數聲明      
 Connection  sqlCon;  //資料庫連接對象      
 Statement  sqlStmt;      
 ResultSet  sqlRst;  //結果集對象      
 String  strCon;  //資料庫連接字串      
 String  strSQL;  //SQL語句      
 int  intPageSize;  //一頁顯示的記錄數      
 int  intRowCount;  //記錄總行數      
 int  intPageCount;  //總頁數      
 int  intPage;  //待顯示頁碼 
 int i; 
/**
 *獲得總的記錄行數
**/
Class.forName("com.mysql.jdbc.Driver").newInstance(); 
strCon  =  "jdbc:mysql://localhost:3306/test"; 
sqlCon  =  java.sql.DriverManager.getConnection(strCon,"root","1"); 
sqlStmt  =  sqlCon.createStatement();            
strSQL  =  "select count(*) from message";      
sqlRst  =  sqlStmt.executeQuery(strSQL); //執行SQL語句並取得結果集            
sqlRst.next();  //記錄集剛開啟的時候,指標位於第一條記錄之前      
intRowCount  =  sqlRst.getInt(1); //擷取總的資料記錄行數     
sqlRst.close();  //關閉結果集 
/**
 *記算總頁數
**/      
intPageCount  =  (intRowCount+intPageSize-1) / intPageSize; 
/**
 *獲得結果集
**/     
strSQL  =  "select  time,mail,content  from message ORDER BY time DESC";           
sqlRst  =  sqlStmt.executeQuery(strSQL); 
//將記錄指標定位到待顯示頁的第一條記錄上      
i  =  (intPage-1)  *  intPageSize; 
for(int j=0;j<i;j++) 
{
   sqlRst.next();
}
/**
 *使用next()以及行數標誌限定當前頁顯示的資料
**/
while(i<intPageSize  &&  sqlRst.next())
{
……
……
<tr>      
<td>使用者名稱:<%=sqlRst.getString("time")%></td>    
</tr>
……
……
}
這種方法是最普遍使用的,對於少量資料用這個方法是可以接受的。但是,如果table中的資料有幾萬幾十萬行呢?全部放入結果集返回?這時,這個方法就不行了。
方法二:
使用資料庫控制,返回當前頁需要顯示的資料。
a.使用mysql控制:
select * from user
order by Host
limit m, n
結果返回的是第m+1行到第n行的資料集。
比如
select * from user
order by Host
limit 1, 5
返回的是第2行到第5行的資料集
b.使用sqlserver
SELECT *
FROM (SELECT TOP m *
        FROM (SELECT TOP n *
                FROM Customers) A
        ORDER BY CustomerID DESC) B
ORDER BY CustomerID
獲得的結果集資料為第n-m+1行到第n行。
對整個過程的解釋:
首先按照升序得到前n行的結果集A,然後按照降序從A中得到後m行的結果集B,最後按照升序對B進行重新排序,返回結果集。
其中CustomerID為主鍵
比如:
SELECT *
FROM (SELECT TOP 5 *
        FROM (SELECT TOP 10 *
                FROM Customers) A
        ORDER BY CustomerID DESC) B
ORDER BY CustomerID
的意思就是返回包含第6行到第10行的資料結果集。
c.使用Oracle: 
select * from (select rownum r ,* from test) tt 
where tt.r > 50 and tt.r <= 100; 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.