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

您所在的位置:网站首页 jsp分页显示mysql 分页显示问题的解决方法(jsp,sqlserver,mysql,oracle)

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

2023-09-28 12:07| 来源: 网络整理| 查看: 265

同学在做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…………      用户名:    …………}

这种方法是最普遍使用的,对于少量数据用这个方法是可以接受的。但是,如果table中的数据有几万几十万行呢?全部放入结果集返回?这时,这个方法就不行了。

方法二:使用数据库控制,返回当前页需要显示的数据。a.使用mysql控制:select * from userorder by Hostlimit m, n结果返回的是第m+1行到第n行的数据集。比如select * from userorder by Hostlimit 1, 5返回的是第2行到第5行的数据集

b.使用sqlserverSELECT *FROM (SELECT TOP m *        FROM (SELECT TOP n *                FROM Customers) A        ORDER BY CustomerID DESC) BORDER 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) BORDER BY CustomerID的意思就是返回包含第6行到第10行的数据结果集。

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



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3