程序员springbootJava 杂谈

Spring Data JPA: 分页和排序实战

2018-07-25  本文已影响96人  紫霞等了至尊宝五百年

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

继承PagingAndSortingRepository

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


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

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

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

通过参数生成Pageable对象

Pageable定义了很多方法,但其核心的信息只有两个:一是分页的信息(page、size),二是排序的信息。Spring Data Jpa提供了PageRequest的具体实现,我们只提供分页以及排序信息即可:



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

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

直接获取Pageable对象


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

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

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

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

返回结果

我们将看到如下结果:



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

上一篇 下一篇

猜你喜欢

热点阅读