ireport 分页配置每也显示多少条_Javaweb的分页功能

c72c7c150425aa4388aa97196c88b096.png

【55】

一、分页的思路

    首先我们得知道写分页代码时的思路,保持思路清晰,有步骤的进行,才能行云如水。先来看看分页的效果

22945a2d861d4067b33e6384c4fb67cb.png

这就是一个分页导航,其中能得到的数据有

    totalRecord:总共员工数,数据库中总的记录数,这里有55条

    totalPage:总页数,11页

    pageSize:每页显示的记录数,这里可以看到每页显示5条

    pageNum:当前页为第几页,比如图中就为第9页,因为9是没有超链接的,

    start:总共能显示5页,让用户进行点击,7为起始页

    end:11为能显示的尾页,也就是,如果用户点击第8页,那么start就为6,end就为10,每次都只有5页共点击查询。

    每次能够得到对应页数所需要的5条数据,等等这些数据都要在jsp中显示出来,也就是说,每次都要从后台拿那么多数据过来进行显示,所以我们就想办法把这些数据封装在一个javabean当中,每次后台都将查询到的数据放入javabean对象中,我们只需要将该对象存入request作用域,然后在jsp页面中从域中获取需要的数据即可。

二、创建PageBean存放数据

    PageBean.java

    总共需要8个属性pageNum、pageSize、totalRecord、totalPage、startIndex、list、start、end,

    pageNum、pageSize、totalRecord:通过构造方法就能得到。pageNum请求页面提交过来的参数,pageSize是自己设置的,totalRecord是查询数据库得到的

    totalPage、startIndex、start、end是通过内部算法得出,

    list需要通过查询数据库在通过set方式得到。

 注意:该类使用泛型是为了不仅仅在这个项目中使用,在别的项目中也同样可以使用,

40f71d2dda990f082df0791482111537.png

代码:

import 

三、在service层编写业务逻辑代码

  其实就是在该层将我们所需要的PageBean对象构建好,返回给上一层

e1e05e86e569fb39a87b2495baf8dbc6.png

User类是我们需要显示的数据的封装后的javabean。 

四、Servlet中编写控制代码

bec2fa7d1c47e73c54132ca0b0592d23.png

五、JSP中显示数据,构建分页导航

       因为将我们所有需要的数据都封装在了pageBean中,pageBean对象又在request域中,所以在jsp页面中,我们只需要拿到我们所需要的数据,进行显示即可,构造导航图需要注意的有一点,逻辑要搞清楚,想要显示什么不想显示什么,全屏自己控制了,只需要记得一点,在请求Servlet时,需要把请求的页码交给服务器。不然服务器不知道你要获得第几页的数据。

       我做的导航图的逻辑代码

       显示所有员工数量、总页数

       首先超链接 

       如果当前页为第一页时,就没有上一页这个超链接显示

       如果当前页不是第一页也不是最后一页,则有上一页和下一页这个超链接显示

       如果当前页是最后一页,则只有上一页这个超链接显示,下一页没有

       尾页超链接 

jsp代码:

<%-- 

六、总结

   其实分页真的很简单,难点就在一个地方,javabean的构建,只要理清楚了pageBean中需要哪些属性,各种属性的作用是什么,那么分页就so easy了。还有一个就是在jsp中写分页导航时的逻辑,不要混乱了。

常见数据库分页:

1.oracle数据库分页
select * from (select a.*,rownum rc from 表名 where rownum<=endrow) a where a.rc>=startrow
2.DB2数据库分页
Select * from (select rownumber() over() as rc,a.* from (select * from 表名 order by列名) as a) where rc between startrow and endrow
3.SQL Server 2000数据库分页
Select top pagesize * from 表名 where 列名 not in(select top pagesize*page 列名 from 表名 order by列名) order by列名
4.SQL Server 2005数据库分页
Select * from (select 列名,row_number() over(order by 列名1) as 别名from 表名) as t where t.列名1>=startrow and t.列名1<=endrow
5.MySQL数据库分页
Select * from 表名 limit startrow,pagesize (Pagesize为每页显示的记录条数)

转载:

Java Web(十一) 分页功能的实现​www.cnblogs.com
d836bd46b2e7a396582b997071f97647.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值