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

原创 2005年04月24日 09:48:00

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


分页显示问题(jsp/sqlserver/mysql/oracle)

方法一:最常用的方法,就是使用直接中数据库中获得所有行的结果集,然后通过定位标志,使用next()。示例代码(数据库使用mysql)://变量声明       Connection  sqlCon; ...
  • rko
  • rko
  • 2005年12月05日 15:56
  • 988

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

同学在做jsp实现一个网上交易平台时一碰到了这个问题,我想这个问题一定具有代表性,因为分页显示技术要用到的地方确实很多。为了减少初学者在这方面花的时间,我在一些资料的基础上,总结了分页显示的方法。方法...
  • sky_zhangfan
  • sky_zhangfan
  • 2008年01月08日 09:59
  • 343

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

同学在做jsp实现一个网上交易平台时一碰到了这个问题,我想这个问题一定具有代表性,因为分页显示技术要用到的地方确实很多。为了减少初学者在这方面花的时间,我在一些资料的基础上,总结了分页显示的方法。方法...
  • lfywy
  • lfywy
  • 2008年08月19日 09:31
  • 426

JSP 分页显示数据 (Oracle)

要实现分页,首先我们要做的就是如何来编写SQL语句,网上也有很多,大家可以搜一下.在这里,我们使用一种比较常用的方式来编写SQL语句。代码如下: ----分页显示 select * from (sel...
  • yulei_qq
  • yulei_qq
  • 2013年11月19日 20:40
  • 6791

oracle,mysql,SqlServer三种数据库的分页查询总结

MySql: MySQL数据库实现分页比较简单,提供了 LIMIT函数。一般只需要直接写到sql语句后面就行了。 LIMIT子 句可以用来限制由SELECT语句返回过来的数据数量,它有一个或两个参...
  • SH_King
  • SH_King
  • 2015年07月31日 15:36
  • 1863

jsp+java bean+mysql数据库进行分页显示

原来没有写过,听朋友说,比较难,就试一下,还是挺简单的,只不过,具体实用方面还得自己写,没有什么难的,自己看看就懂了。bean文件:package bean;/** * jsp+java bean+m...
  • fenglibing
  • fenglibing
  • 2007年06月24日 17:33
  • 8752

jsp+MySQL的查询结果分页显示[实例]

已验证可以执行的代码。 初学,谨作为个人学习记录。 请大家给出意见或建议。谢谢!    //驱动程序名,比较旧了,如果你用mysql5,自己改。  String driv...
  • sj1900
  • sj1900
  • 2010年10月18日 00:07
  • 7355

jsp的分页查询的代码(mysql数据库)

这个功能一共创建了两个javabean组件和一个jsp页面显示分页页面,第一个是处理以数据库连接的javabean,第一个javabean是处理分页查询结果的代码,第三个jsp是调用第二个javabe...
  • jxzhoumin
  • jxzhoumin
  • 2007年11月25日 11:29
  • 4748

JSP页面分页显示数据

一、源代码(这里以一个Java web的留言板项目为例): 1.Dao层操作数据库的方法(MessageDao.java) 设置每页显示的最大留言条数: private final int MAX...
  • u013539342
  • u013539342
  • 2015年05月30日 13:40
  • 5202

JSP实现数据库分页显示源代码

分页显示数据库信息 分页显示数据库记录     用户名     性别     电话     E-Mail try { //驱动程序名 String dri...
  • Java958199586
  • Java958199586
  • 2011年11月06日 17:58
  • 6729
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:分页显示问题的解决方法(jsp,sqlserver,mysql,oracle)
举报原因:
原因补充:

(最多只允许输入30个字)