IT修真院·小课堂丨互联网职业小课堂在线学习平台

课堂课题:

SpringMVC分页查询和显示

关联任务:

任务五

直播时间:

2018-11-01 19:30:00


课堂内容:

视频链接:

PPT链接:

提交按钮:

小课堂内容格式


标题:

【修真院xx(职业)小课堂】课题名称

开场语:

大家好,我是IT修真院XX分院第X期的学员XX,一枚正直纯洁善良的XX程序员,今天给大家分享一下,修真院官网XX(职业)任务X,深度思考中的知识点——XXX

(1)背景介绍:

背景介绍的时候,尽可能的要宽广,讲清楚来龙去脉,讲清楚为什么会需要这个技术。

(2)知识剖析:

讲知识点的时候,尽可能的成体系,学会成体系的去给别人介绍知识。现在很多做的都是零散的,没有分类。

(3)常见问题:

最少列出1个常见问题。

(4)解决方案:

写清楚常见问题的解决方案。

(5)编码实战:

尽可能的去寻找在真实项目中在用的。如果你能找到某个网站在用你说的知识点,这是最好的。学以致用,否则当成练习题就没有意义了。多准备一些demo,讲解过程中将知识点和demo结合,便于大家理解所讲解的知识点。

(6)拓展思考:

知识点之外的拓展思考,由分享人进行讲解,这些东西就是所谓的深度,也是一个人技术水准高低比较的表现。

(7)参考文献:

引入参加文献的时候,在引用的句子后面加上序号【1】。参考文献中列出详细来源。不要去抄别人的东西,这是一个基本的态度。

(8)更多讨论:

Q1:提问人:问题?
A1:回答人(可以是分享人,也可以是其他学员):回答
Q2:提问人:问题?
A2:回答人(可以是分享人,也可以是其他学员):回答
Q3:提问人:问题?
A3:回答人(可以是分享人,也可以是其他学员):回答

(9)鸣谢:

感谢XX、XX师兄,此教程是在他们之前技术分享的基础上完善而成。

(10)结束语:

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

SpringMVC分页查询和显示     中品

辅导师兄 [修真长老]CSS-僵尸集中营


【修真院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.结束语:


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


评论

[武汉|结业弟子]JAVA-李伟明 发表于 2018-11-06 14:51:10 #1

mybatis 分页查询 插件的 各个类的属性都有介绍到,以及使用需要注意的地方都有讲到,讲解还算可以

回复

请您登录 后进行评论