为了账号安全,请及时绑定邮箱和手机立即绑定

Spring Data JPA: 分页和排序实战

标签:
Java

之前我们学习了使用Jpa访问关系型数据库
通过Jpa大大简化了我们对数据库的开发工作。但是,之前的例子中我们只提到了最简单的CRUD。
实际上,Spring Data Jpa对于分页以及排序的查询也有着完美的支持,接下来,我们来学习如何通过Pageable来对数据库进行分页查询。

继承PagingAndSortingRepository

Jpa的基本使用方法在使用Jpa访问关系型数据库已经介绍过,我们暂且跳过,这里我们直接来看接口UserApplyRepository的定义:

https://img1.sycdn.imooc.com//5bcc4abf0001608410000533.jpg


我们可以看到,UserApplyRepository定义了这样一个方法:Page<Blog> findByDeletedFalse(Pageable pageable);,我们主要关注它的参数以及返回值。


  • Pageable 是Spring Data库中定义的一个接口,该接口是所有分页相关信息的一个抽象,通过该接口,我们可以得到和分页相关所有信息(例如pageNumber、pageSize等),这样,Jpa就能够通过pageable参数来得到一个带分页信息的Sql语句


    5bcc4a82000170fb10000807.jpg

  • Page类也是Spring Data提供的一个接口,该接口表示一部分数据的集合以及其相关的下一部分数据、数据总数等相关信息,通过该接口,我们可以得到数据的总体信息(数据总数、总页数...)以及当前数据的信息(当前数据的集合、当前页数等)


    5bcc4a83000192ed10000815.jpg

Spring Data Jpa除了会通过命名规范帮助我们扩展Sql语句外,还会帮助我们处理类型为Pageable的参数,将pageable参数转换成为sql'语句中的条件,同时,还会帮助我们处理类型为Page的返回值,当发现返回值类型为Page,Spring Data Jpa将会把数据的整体信息、当前数据的信息,分页的信息都放入到返回值中。这样,我们就能够方便的进行个性化的分页查询。

Pageable只是一个抽象的接口,那么,家下来我们学习如何获得pageable对象

通过参数生成Pageable对象

Pageable定义了很多方法,但其核心的信息只有两个

  • 分页的信息(page、size)

  • 排序的信息

Spring Data Jpa提供了PageRequest的具体实现,我们只提供分页以及排序信息即可:

5bcc4a840001144310000190.jpg


5bcc4a840001273f09590128.jpg


在这里,我们通过参数获得分页的信息,并通过Sort以及Direction告诉pageable需要通过id降序排列


这里可以看到,通过参数来得到一个pageable对象还是比较繁琐的,当查询的方法比较多的时候,会产生大量的重复代码。为了避免这种情况,Spring Data提供了直接生成pageable的方式

直接获取Pageable对象


5bcc4a86000102b010000086.jpg


只需要在方法的参数中定义一个Pageable类型参数,当Spring发现这个参数时会自动的根据request的参数来组装该Pageable对象
Spring支持的request参数如下


  • page,第几页,从0开始,默认为第0页

  • size,每一页的大小,默认为20


    5bcc4a86000123ba10000034.jpg

  • sort,排序相关的信息,以property,property(,ASC|DESC)的方式组织,例如sort=firstname&sort=lastname,desc表示在按firstname正序排列基础上按lastname倒序排列

这样,我们就可以通过url的参数来进行多样化、个性化的查询,而不需要为每一种情况来写不同的方法了。

通过url来定制pageable很方便,但唯一的缺点是不太美观,因此我们需要为pageable设置一个默认配置,这样很多情况下我们都能够通过一个简洁的url来获取信息了。

Spring data提供了@PageableDefault帮助我们个性化的设置pageable的默认配置
例如@PageableDefault(value = 15, sort = { "id" }, direction = Sort.Direction.DESC)表示默认情况下我们按照id倒序排列,每一页的大小为15

返回结果

我们将看到如下结果:


5bcc4a870001ee2206230994.jpg


通过查询结果,我们可以知道:
以id倒序排列的10条数据
当前页不是最后一页,后面还有数据
总共有9页
每页大小为15
当前页为第0页
当前页是第一页
当前页是以id倒序排列的
当前页一共有15条数据
怎么样,信息是不是很丰富,代码是不是很简单,快点来尝试一下Jpa的分页查询吧



作者:芥末无疆sss
链接:https://www.jianshu.com/p/0e9e1c772374
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消