Spring Data JPA实现分页Pageable的实例代码
程序员文章站
2024-02-07 14:38:10
在jpa中提供了很方便的分页功能,那就是pageable(org.springframework.data.domain.pageable)以及它的实现类pagereque...
在jpa中提供了很方便的分页功能,那就是pageable(org.springframework.data.domain.pageable)以及它的实现类pagerequest(org.springframework.data.domain.pagerequest),详细的可以见示例代码。
1、改变customerrepository方法
/** * 一个参数,匹配两个字段 * @param name2 * @param pageable 分页参数 * @return * 这里param的值和=:后面的参数匹配,但不需要和方法名对应的参数值对应 * 这里增加了@queryhints注解,是给查询添加一些额外的提示 * 比如当前的name值为hint_comment是在查询的时候带上一些备注信息 */ @queryhints(value = { @queryhint(name = hint_comment, value = "a query for pageable")}) @query("select c from customer c where c.firstname=:name or c.lastname=:name") page<customer> findbyname(@param("name") string name2,pageable pageable);
2、增加customercontroller方法pageable
/** * 分页 * 应用查询提示@queryhints,这里是在查询的适合增加了一个comment * 查询结果是lastname和firstname都是bauer这个值的数据 */ @requestmapping("/pageable") public void pageable(){ //pageable是接口,pagerequest是接口实现 //pagerequest的对象构造函数有多个,page是页数,初始值是0,size是查询结果的条数,后两个参数参考sort对象的构造方法 pageable pageable = new pagerequest(0,3, sort.direction.desc,"id"); page<customer> page = repository.findbyname("bauer",pageable); //查询结果总行数 system.out.println(page.gettotalelements()); //按照当前分页大小,总页数 system.out.println(page.gettotalpages()); //按照当前页数、分页大小,查出的分页结果集合 for (customer customer: page.getcontent()) { system.out.println(customer.tostring()); } system.out.println("-------------------------------------------"); }
从示例代码的注释当中可以看到page对象的相关参数及值的说明,更详细的用法,参考pagerequest源码。
小结:怎么样,是不是很简单很方便?!
参考:
官方文档,
demo,
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: C#使用NPOI上传excel
下一篇: 关于C#中ajax跨域访问问题
推荐阅读
-
Spring Data JPA实现分页Pageable的实例代码
-
ajax完美实现两个网页 分页功能的实例代码_PHP教程
-
PHP分页初探 一个最简单的PHP分页代码的简单实现_php实例
-
yii2分页之实现跳转到具体某页的实例代码_php实例
-
ajax完美实现两个网页 分页功能的实例代码_php实例
-
使用原生javascript实现分页效果的代码实例
-
yii2分页之实现跳转到具体某页的实例代码_php实例
-
Spring Data Jpa+SpringMVC+Jquery.pagination.js实现分页示例
-
Spring boot + mybatis + Vue.js + ElementUI 实现数据的增删改查实例代码(一)
-
Spring boot + mybatis + Vue.js + ElementUI 实现数据的增删改查实例代码(二)