想用JAVA WEB 实现分页技术。请问应该怎么做

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了想用JAVA WEB 实现分页技术。请问应该怎么做相关的知识,希望对你有一定的参考价值。

具体来说就是希望从数据库每次只取一部分结果,这样每页就显示那些结果,这样的分页技术应该怎么是实现呢?或者说有哪些资料可以参考一下?书也行。谢了

实现原理很简单,就是建立一个Page类,里面放当前访问的页数(这个是从客户浏览器传到后台的数据,所以你的分页需要用它来定位记录的条目)和每一页显示的记录行数。然后通过分页计算就可以得出下列数据。
(假定你的页数从1开始)
1、总页数 = 总记录数/每页大小,如果0!=总记录数%每页大小,那么总页数再+1
2、当前页数(从浏览器传递的参数中获得)
3、表记录的起始位置=(当前页数-1)*每页大小
4、总记录数(select count(*) from [表名] [where [条件]],从数据库中查询得到)
5、每页大小,可以固定,也可以从页面传过来

有了这几个参数之后,就用sql语句查出对应的记录就可以了。
mysql数据库用limit 表记录的起始位置,每页大小 语句添加到你的查询语句最后面
sqlserver数据库用top语句和not in 来做
oracle数据库用rownum来做

再给你一段分页对象代码,你自己先读一下

public class Page

private long totalCount = 0;// 总记录数
private int pageNumber = 1;// 当前页号,默认显示第一页
private int pageSize = 20; // 每页大小,默认每页20条
private int totalPage = 0;// 总页数,默认为0
private int startRow = 0;// 起始记录行号,默认为从表头开始

/**
* 分页计算方法,由setTotalCount调用
*/
public void pagination()
// 计算总页数
if (this.totalCount % pageSize == 0)
this.totalPage = new Long(this.totalCount / pageSize).intValue();
else
this.totalPage = new Long(this.totalCount / pageSize).intValue() + 1;
// 排除错误页号
if (this.pageNumber < 1)
this.pageNumber = 1;
if (this.pageNumber > this.totalPage)
this.pageNumber = this.totalPage;
// 计算起始行号
this.startRow = (this.pageNumber - 1) * this.pageSize;


public long getTotalCount()
return totalCount;


public void setTotalCount(long totalCount)
this.totalCount = totalCount;
this.pagination();


public int getPageNumber()
return pageNumber;


public void setPageNumber(int pageNumber)
this.pageNumber = pageNumber;


public int getPageSize()
return pageSize;


public void setPageSize(int pageSize)
this.pageSize = pageSize;


public int getTotalPage()
return totalPage;


public void setTotalPage(int totalPage)
this.totalPage = totalPage;


public int getStartRow()
return startRow;


public void setStartRow(int startRow)
this.startRow = startRow;


参考技术A

利用数据库的分页:

如MYSQL 使用limit pageNum,pagesize

EG:

   

SELECT * FROM TABLE1 WHERE ... ORDER  BY .. GROUP BY ... LIMIT 0,10

limit必须放在最后从0开始(即0是第一页),其中pageNum是当前第几页,pagesize是每页显示多少条。

ORACLE 分页:

oracle分页可使用rowid,rownum来分页,详见:http://www.cnblogs.com/hxw/archive/2005/09/11/234619.html


参考技术B mysql 用 limit
oracle 用 使用rowid,rownum来分页
sqlserver 用 top实现
1.Oracle:select * from ( select row_.*, rownum rownum_ from ( query_SQL ) row_ where rownum =< max) where rownum_ >= min2.SQL Server:select top @pagesize * from tablename where id not in (select top @pagesize*(@page-1) id from tablename order by id) order by id

3.MySQLselect * from tablename limit position, counter

4.DB2select * from (select *,rownumber() as ROW_NEXT from tablename) where ROW_NEXT between min and max
参考技术C

select * from 

(

     SELECT  row_number() OVER(ORDER by id) as rownum,id,name

        from test1  

 ) t where t.rownum between pageSize*(page-1)+1 and pageSize*page

JAVA中我想用IO流把服务器上的文件保存到本机

我这是远程服务器。 需要晚上把服务器上的文件下载到本机
我用的IO流 不过我设置的路径他直接保存到服务器上了
请问我要保存到本机上面来 路径应该怎么设置。

理论上讲这是不行的!除非你手动进行远程下载,因为服务器不能自动操作客户机,这样做无异于病毒。 参考技术A 如果请求的话,对方同意,可以实现。 参考技术B 有公网固定IP的话,把IP地址设置上,试验一下

以上是关于想用JAVA WEB 实现分页技术。请问应该怎么做的主要内容,如果未能解决你的问题,请参考以下文章

我想用nodejs操作摄像头,获得摄像头的实时数据流,该怎么做?没思路求指导

请问下,我想用java实现下载excel表格,思路是先在临时文件里生成临时excel文件,但是不知

JAVA中我想用IO流把服务器上的文件保存到本机

java用FileDialog怎么打开和保存文件

我想用arduino leonardo的串口即0脚和1脚连接XBEE传输数据,并由电脑接收,请问应该怎么实现。

java中的mongoDB怎么分页,要代码,数据量较大