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

news/2024/5/18 22:43:26 标签: MySQL, JSP, Oracle, SQL, JDBC

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



http://www.niftyadmin.cn/n/605322.html

相关文章

职场十年经验和能力无关

我一直在想&#xff0c;为什么看到很多的人在外边闯荡十几年&#xff0c;为什么还是一个普通的员工&#xff0c;没有高薪&#xff0c;只有高龄&#xff0c;经验和资历固然重要&#xff0c;但这并不是衡量经验和才华的标准。有些人十年的经验&#xff0c;只不过是一年经验的重复…

auto_setup接口 connect_device | init_device

auto_setup是一个用来初始化环境的接口&#xff0c;它接受5个参数。我们可以设置当前脚本所在路径&#xff0c;指定运行脚本设备、设置默认的log路径、设置脚本父路径和指定截图精度 auto_setup(basedirNone,devicesNone,logdirNone,project_rootNone,compress0) 自动配置运行…

部署cmp时的教训

原来数据库服务器随系统启动而启动&#xff0c;前几天把数据库服务改为手动启动后一直没有部署过cmp&#xff0c;直到昨晚做cmp作业时&#xff0c;部署cmp jboss就报出n多错误&#xff0c;眼花缭乱啊。还没等报完错误&#xff0c;我就关了jboss&#xff0c;心想怎么会这样的呢&…

关于Remoting

这几天看了不少Remoting文章。明白了不少技术细节&#xff0c;但困惑也不少。简单说来&#xff0c;Remoting是一个分布式处理服务。服务器端首先创建通道&#xff08;Channel&#xff09;&#xff0c;并自动开启监听通道。根据客户端发出的请求&#xff0c;传递远程对象。 因此…

语法技巧(三目运算符、switch...case...)

一、三目运算符 三目运算符的一种简便写法&#xff1a; bool b str "abc" ? false : true; 当是自身时&#xff0c;实际上别吝啬那一个括号&#xff0c;有一个括号&#xff0c;实际上更容易一看就看懂&#xff1a; int i 0;i (i 0) ? 1 : 0; 实际上这样的代码…

.NET Remoting 体系结构评估

.NET Remoting 体系结构评估 Pat MartinMicrosoft Corporation 2003年5月 适用于&#xff1a;Microsoft .NET FrameworkMicrosoft .NET Remoting 摘要&#xff1a;本文适用于要将 .NET Remoting 用于分布式多层应用程序设计的人员。文章从开发人员的角度介绍了该技术的功能。…

__init__构造方法

属性是变量&#xff0c;方法是函数 函数使用变量就是面向对象self.是为了使变量能在类中跨函数使用。 不写self. python只能在当前函数中找变量。写上self.python会在当前类中找变量class Mystuff(object):def __init__(self):self.age 18def print_age(self):age1print(age…

关于Remoting(续)

昨天写了文章《关于Remoting》&#xff0c;感觉有些问题没有说清楚。后来又看了一些文档和书&#xff0c;整理了一下&#xff0c;就算是续吧。 其实我发现主要的问题还是集中在客户端激活模式。我想再谈谈客户端激活模式和服务器端激活模式两者在代码实现上的区别。这两种模式在…