Java分页查询--分页显示(实例讲解)
作者:jingxian 发布时间:2023-02-05 11:07:15
标签:java,分页查询,分页显示
当数据库中数据条数过多时,一个页面就不能显示,这是要设置分页查询,首先要使用的是数据库sql语句的limit条件实现分组查询
sql语句大概形式为:
select * from table limit 开始索引,显示条数
用该语句就会实现分块查询,并且每页显示固定条数。
首先要实现后台分页,我们需要知道它有多少页,每页有多少行,这就需要知道一共多少行,调用sql语句时还需要知道每一页的开始索引,开始索引是根据当前页数算出来的,所以还需要知道当前页数,查询后会返回一个列表存储当前页数据。将这些属性及获取设置的方法封装成一个类就有了下面的page类:
Page类
public class Page<T> {
private List<T> data;//数据列表
private int pagenum;//当前页数
private int pagesize;//当前页显示条数
private int rows;//总行数
public Page(int rows,int pagenum, int pagesize) {
super();
data=new ArrayList<>();
this.rows=rows;
this.setPagesize(pagesize);
this.setPagenum(pagenum);
}
public Page() {
super();
}
public int getPagenum() {
return pagenum;
}
public void setPagenum(int pagenum) {
if(pagenum>getTotalpage())
{
this.pagenum=getTotalpage();
}
else {
this.pagenum = pagenum;
}
if(pagenum<1)
{
this.pagenum=1;
}
}
public int getPagesize() {
return pagesize;
}
public void setPagesize(int pagesize) {
this.pagesize = pagesize;
}
public int getTotalpage() {
//计算总页数
if(rows%pagesize==0)
{
return rows/pagesize;
}
else {
return rows/pagesize+1;
}
}
public int getRows() {
return rows;
}
public void setRows(int rows) {
this.rows = rows;
}
public int getIndexnum() {
//获取索引值
return pagesize*(pagenum-1);
}
public List<T> getData() {
return data;
}
public void setData(List<T> data) {
this.data = data;
}
}
初始化时我们只需要获得数据总条数,页数及每页显示条数。数据总条数可以用sql语句select count(*)from table 获得。每次查询时只需要传入当前页数就可以了。将每次查询后的page对象传入jsp前台页面,并以一个div来显示
显示div
<div>
<a href="/stuent8.11/stuServlet?pagenum=1" rel="external nofollow" >首页</a>
<a href="/stuent8.11/stuServlet?pagenum=${apage.pagenum-1 }" rel="external nofollow" >上一页</a>
<c:choose>
<c:when test="${apage.totalpage<=5 }">
<c:set var="begin" value="1"></c:set>
<c:set var="end" value="${apage.totalpage }"></c:set>
</c:when>
<c:when test="${apage.totalpage>5 }">
<c:set var="begin" value="1"></c:set>
<c:set var="end" value="5"></c:set>
<c:if test="${apage.pagenum>3 }">
<c:set var="begin" value="${apage.pagenum-2 }"></c:set>
<c:set var="end" value="${apage.pagenum+2 }"></c:set>
</c:if>
<c:if test="${end>apage.totalpage }">
<c:set var="begin" value="${apage.totalpage-4 }"></c:set>
<c:set var="end" value="${apage.totalpage }"></c:set>
</c:if>
</c:when>
</c:choose>
<c:forEach begin="${begin }" end="${end }" step="1" var="num">
<c:if test="${apage.pagenum==num }">
[${num }]
</c:if>
<c:if test="${apage.pagenum!=num }">
<a href="/stuent8.11/stuServlet?pagenum=${num }" rel="external nofollow" >${num }</a>
</c:if>
</c:forEach>
<a href="/stuent8.11/stuServlet?pagenum=${apage.pagenum+1 }" rel="external nofollow" >下一页</a>
<a href="/stuent8.11/stuServlet?pagenum=${apage.totalpage }" rel="external nofollow" >末页</a>
</div>
其中的一个choose是用于规定页面显示的最大页数,这里是5页,就是说当点到第4页是时,第1页就会消失,出现第6页。
来源:http://www.cnblogs.com/PersistWp/archive/2017/08/14/7360000.html
0
投稿
猜你喜欢
- 省流/// <summary>/// 是否有效的文件,文件夹路径/// </summary>/// <para
- 前言Android 开发中,我们经常需要实现图片的圆形/圆角的效果,我们可以使用两种方式来实现这样的效果。一种是使用Xfermode,另一种
- 最近项目需要,需要做一个BMI指数的指示条,先上效果图: BMI指数从18到35,然后上面指示条的颜色会随着偏移量的变化而改变,数字显示当前
- 1 概念方面List是接口,ArrayList是List接口的一个实现类2 初始化方面2.1 List2.1.1 错误写 * ist list
- 本文借由并发环境下使用线程不安全的SimpleDateFormat优化案例,帮助大家理解ThreadLocal.最近整理公司项目,发现不少写
- springboot读取配置文件到静态工具类通常我们读取配置文件可以用@Value注解和@Configuration,@Configurat
- 创蓝253: https://www.253.com/#region 获取手机验证码(创蓝253) /// <summar
- 本文实例为大家分享了Android仿微信二维码和条形码的具体代码,供大家参考,具体内容如下package your.QRCode.names
- 本文实例讲述了java数据结构排序算法之树形选择排序。分享给大家供大家参考,具体如下:这里我们就来说说选择类排序之一的排序:树形选择排序在简
- 一、Netty简介Netty 是一个基于NIO的客户、服务器端的编程框架,使用Netty 可以确保你快速和简单的开发出一个网络应用,例如实现
- 1.概述最近一直都在带实习生做项目,发现自己好久没有写博客了,这几天更新会比较频繁,今天玩QQ的时候发现QQ主页菜单滑动效果早就变了,实在忍
- Eclipse提供了一个可扩展插件的开发系统。这就使得Eclipse在运行系统之上可以实现各种功能。这些插件也不同于其他的应用(插件的功能是
- 一、Intent的用途Intent主要有以下几种重要用途: 1. 启动Activity:可以将Intent对象传递给startActivit
- 一、int还记得 C 语言里的 int 吗,C里面的 int 有着无符号与有符号之分但是Java内就没有,且固定占4个字节大小,也就是32比
- 一、版本说明spring3.1以下的版本必须使用quartz1.x系列,3.1以上的版本才支持quartz 2.x,不然会出错。原因:spr
- 本文实例为大家分享了java实现幸运抽奖功能的具体代码,供大家参考,具体内容如下本系统较为简单,未使用是什么多的算法,也未添加保存文件读取文
- 最近在搭建springmvc的框架,遇到的这样的问题:在地址栏访问登陆界面访问不了,http://localhost/XXXX/WEB-IN
- 本文实例讲述了Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法。分享给大家供大家参考,具体如下
- 今天一个读者问我关于Android通过调用Webservice实现天气预报这篇文章的源码下载后出现的错误Could not find cla
- java匿名内部类:1:匿名内部类,匿名内部类也就是没有名字的内部类。2:匿名内部类的作用正因为没有名字,所以匿名内部类只能使用一次,它通常