SpringMVC分页查询和显示

这里是修真院后端小课堂,每篇分享文从

【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】

八个方面深度解析后端知识/技能,本篇分享的是:

【SpringMVC分页查询和显示】

【修真院Java小课堂】SpringMVC分页查询和显示

大家好,我是IT修真院武汉分院第17期的学员王志雄,一枚正直纯洁善良的Java程序员,今天给大家分享一下,修真院官网Java(职业)任务二,深度思考中的知识点——SpringMVC分页查询和显示

1. 背景介绍

为什么需要用到分页查询??

1、用户体验、页面显示效果: 在开发过程当中,我们经常需要从数据库中查询数据,然后将数据在客户端显示,如果数据量少的话,可以在一个页面上显示完成,但是如果查询的数据是几百条、上千条数据的时候,全部在一个页面上显示出来,非常影响页面的美观性和用户的体验。所以这就用到分页技术。

2、服务器资源、性能: 当数据量过大时,可能会导致各种各样的问题发生,例如:服务器资源被耗尽,因数据传输量过大而使处理超时,等等。最终都会导致查询无法完成当数据量过大时,可能会导致各种各样的问题发生,例如:服务器资源被耗尽,因数据传输量过大而使处理超时,等等。最终都会导致查询无法完成

2. 知识剖析

分页查询优点

分页查询优点:

排版清晰,界面美观

每页信息数量固定,查询效率快

根据用户的需要,提供适当的数据

提高性能,减少内存的压力,提高访问速度

分页查询分类:

逻辑分页

逻辑分页是在用户第一次访问时,将数据库的所有记录全部查询出来, 添加到一个大集合中,然后存放在session对象,再通过页码计算出当前页需要显示的数据内容, 存储到一个小的list的集合中,并将其存储到request对象中,跳转到JSP页面,进行遍历显示。 当用户第二次访问时,只要不关闭浏览器,还会从session中获取数据,来进行显示。

缺点:

如果需要查询的数据量过大,session将耗费大量的内存; 因为是在session中获取数据,如果第二次或者更多此的不关闭浏览器访问,会直接访问session, 从而不能保证数据是最新的。

优点:优点:

统一代码处理方式,较容易跨数据库做迁移。

物理分页

物理分页使用数据库自身所带的分页机制,例如,Oracle数据库的rownum, 或者Mysql数据库中的limit等机制来完成分页操作。因为是对数据库的数据进行分页条件查询, 所以叫物理分页。每一次物理分页都会去连接数据库。

优点:

数据能够保证最新,由于根据分页条件会查询出少量的数据,所以不会占用太多的内存。

2.知识剖析

何为分页技术?

分页就是将一段长长的数据,按照特定的长度(数量)进行分开显示

分页的核心技术: 分页的核心简单地讲,就是计算每页多少记录和总页数以及第几页。

1、要实现分页显示,需要用到哪些参数

private int currPage;//当前页数

private int pageSize;//每页显示的记录数

private int totalCount;//总记录数

private int totalPage;//总页数

private List lists;//每页的显示的数据

2、需要用到的语句有

1.select count(*) from ...:查询得到记录总条数

2.select * from .. limit pageNo,rowsCount:查询从第pageNo条开始的rowsCount条数据。

3.常见问题

SSM框架怎么进行分页查询处理?将数据保存在什么位置?

4.解决方案

在page类中创建集合属性,将数据保存在此集合中

 

5.编码实战

6.扩展思考

PageHelper的优缺点?

优点:封装分页sql,使我们不需要每个地方都去写分页的查询语句;同时,使我们select的sql语句向下兼容,换了数据库也不需要更改sql代码;

缺点:自带的Page对象转json时会丢失分页数据;而转为PageInfo对象时分页信息过多

7.参考文献

https://zhidao.baidu.com/question/168096244.html

https://www.cnblogs.com/geningchao/p/6649907.html

https://blog.csdn.net/weixin_41267342/article/details/79151098

 

8.更多讨论

PageHelper支持哪些数据库?

Mybatis分页插件  支持Oracle、Mysql、MariaDB、SQLite、Hsqldb、PostgreSQL六种数据库  不支持SQL Server,Java开发很少使用SQL数据库

什么时候会导致不安全的分页?
PageHelper 方法使用了静态的 ThreadLocal 参数,分页参数和线程是绑定的。

只要你可以保证在 PageHelper 方法调用后紧跟 MyBatis 查询方法,这就是安全的。因为 PageHelper 在 finally 代码段中自动清除了 ThreadLocal 存储的对象。

4.X和5.X的配置?

5.x版本开始使用com.github.pagehelper.PageInterceptor新版拦截器。总的来说,pagehelper4.x就该用4.x的配置,pagehelper5.x就用5.x的配置(官方推荐)

9.鸣谢

感谢观看,如有出错,恳请指正

10.结束语:

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

PPT链接 视频链接

更多内容,可以加入IT交流群565734203与大家一起讨论交流

这里是技能树·IT修真院:,初学者转行到互联网的聚集地

相关文章

开发过程中是不可避免地会出现各种异常情况的,例如网络连接...
说明:使用注解方式实现AOP切面。 什么是AOP? 面向切面编程...
Spring MVC中的拦截器是一种可以在请求处理过程中对请求进行...
在 JavaWeb 中,共享域指的是在 Servlet 中存储数据,以便在...
文件上传 说明: 使用maven构建web工程。 使用Thymeleaf技术...
创建初始化类,替换web.xml 在Servlet3.0环境中,Web容器(To...