分享
 
 
 

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

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

转贴请注明本贴地址以及原作者:与莫扎特相遇(bobrow)

http://dev.csdn.net/article/68/68461.shtm

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有