分页显示问题的解决方法(jsp,sqlserver,mysql,oracle)__教程 |
|
日期:2007-5-20 0:37:47 人气:57 [大 中 小] |
|
|
|
同学在做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{ sqlRst.next(); } /** *使用next()以及行数标志限定当前页显示的数据 **/ while(i{ …… ……
用户名:<%=sqlRst.getString("time")%> |
…… …… |
|
出处:本站原创 作者:佚名 |
|
|