分页显示问题的解决方法(jsp,sqlserver,mysql,oracle)
转贴请注明本贴地址以及作者:与莫扎特相遇(bobrow)
同学在做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";
补充:Jsp教程,Jsp/Servlet开发工具