转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> MySql >> 正文
分页显示问题的解决方法(jsp,sqlserver,mysql,oracle)         ★★★★

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

作者:闵涛 文章来源:闵涛的学习笔记 点击数:757 更新时间:2009/4/22 20:48:34

转贴请注明本贴地址以及原作者:与莫扎特相遇(bobrow)

http://dev.csdn.net/article/68/68461.shtm

同学在做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;


[MySql]PHP存取 Mysql 数据乱码终极解决方案  [MySql]解决Table xxx is marked as crashed and should …
[MySql][MySQL]快速解决"is marked as crashed and shoul…  [MySql]MySQL DELETE语法用法详解
[MySql]mysql中时间日期格式化  [MySql]修改mysql导入文件大小限制
[其他]手工升级ACCESS到SQLSERVER方法详解  [其他]MySql常用命令大全
[Web开发]把ACCESS的数据导入到Mysql中的方法详解  [Web开发]asp+sqlserver 分页方法(不用存储过程)
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台