这里是修真院后端小课堂,每篇分享文从
【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】
八个方面深度解析后端知识/技能,本篇分享的是:
大家好,我是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.常见问题
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.更多讨论
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.结束语:
今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~
更多内容,可以加入IT交流群565734203与大家一起讨论交流
这里是技能树·IT修真院:nofollow">https://www.jnshu.com,初学者转行到互联网的聚集地