分页显示问题的解决方法(jsp,sqlserver,mysql,oracle)

方法一:最常用的方法,就是使用直接中数据库中获得所有行的结果集,然后通过定位标志,使用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行的数据结果集。

或者

pageSize :每页显示记录数

pageNum:页数

SELECT  top  pageSize * FROM  tb_user    WHERE id(表主键) not in  (select  top  (pageSize*(pageNum-1)) id from tb_user order by id)  order by id

c.使用Oracle:  select * from (select rownum r ,* from test) tt  where tt.r > 50 and tt.r <= 100; 

本文转自:http://www.newasp.net/tech/java/15664.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值