分页显示(jsp,sqlserver,mysql,oracle)

分页显示(jsp,sqlserver,mysql,oracle)

方法一:
最常用的方法,就是使用直接中数据库中获得所有行的结果集,然后通过定位标志,使用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")%>

……
……
}


这种方法是最普遍使用的,对于少量数据用这个方法是可以接受的。但是,如果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为主键

你可能感兴趣的:(Java)