课堂课题:
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)结束语:
今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~
【修真院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 分页查询 插件的 各个类的属性都有介绍到,以及使用需要注意的地方都有讲到,讲解还算可以
回复