博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
浅谈Java分页技术
阅读量:5063 次
发布时间:2019-06-12

本文共 856 字,大约阅读时间需要 2 分钟。

话不多言、我们要实现java分页技术,我们首先就需要定义四个变量,他们是:

int  pageSize;//每页显示多少条记录

int pageNow;//希望现实第几页

int pageCount;//一共有多少页

int rowCount;//一共有多少条记录

说明:

1.pageSize是指定的

2.pageNow是用户选择的

3.rowCount是从表中查询得到的

4.pageCount是计算得到的,该计算为:

if(rowCount%pageSize==0)

{

  pageCount=rowCount/pageSize;

}

else

{

  pageCount=rowCount/pageSize+1;

}

以上说明可能大家听的有点云里雾里,我来举个例子具体说明一下:

有用户表,共9条记录,即:rowCount;每页显示3条记录,即:pageSize=3;那么根据我们的算法:pageCount=3,刚好不多不少,如果每页显示四条记录,pageSize=4,那么pageCount=3,那么最后一页只会有1条记录,所以,不管怎样都是正确的。

针对前面提出的问题,我们很容易想到,使用select 字段名列表 from 表名 where id between ? and ?

我们以一个users表为例,显示第三页,该查询语句就是:select * from users userId between 7 and 9;

这个sql语句确实是比较快,但是它有一个问题,就是如果表的id被删除了,那么,某页可能就会少一条记录。在Sqlserver的查询分析器中实验一下,因此我们的最终解决方法是如下语句:

select top pageSize 字段名列表 from 表名 where id not in(select top pageSize*(pageNow-1) id from 表名);

转载于:https://www.cnblogs.com/Jasxu/p/java_fenye.html

你可能感兴趣的文章
轻松学MVC4.0–6 MVC的执行流程
查看>>
4.9 Parser Generators
查看>>
[10月18日的脚本] 从Access中导入多个表到Excel
查看>>
centos下安装nginx
查看>>
redis集群如何清理前缀相同的key
查看>>
linux的学习系列 9--网络通信
查看>>
redis7--hash set的操作
查看>>
20.字典
查看>>
Python 集合(Set)、字典(Dictionary)
查看>>
oracle用户锁定
查看>>
(转)盒子概念和DiV布局
查看>>
Android快速实现二维码扫描--Zxing
查看>>
获取元素
查看>>
nginx+lighttpd+memcache+mysql配置与调试
查看>>
ubuntu12.04 启动apache2 对.htaccess 的支持
查看>>
proxy写监听方法,实现响应式
查看>>
23种设计模式 简介
查看>>
677. Map Sum Pairs
查看>>
sass列表函数
查看>>
MySQL之常用SQL语句
查看>>