Spring Data JPA實現(xiàn)分頁Pageable的實例代碼
在JPA中提供了很方便的分頁功能,那就是Pageable(org.springframework.data.domain.Pageable)以及它的實現(xiàn)類PageRequest(org.springframework.data.domain.PageRequest),詳細的可以見示例代碼。
1、改變CustomerRepository方法
/** * 一個參數(shù),匹配兩個字段 * @param name2 * @Param pageable 分頁參數(shù) * @return * 這里Param的值和=:后面的參數(shù)匹配,但不需要和方法名對應的參數(shù)值對應 * 這里增加了@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這個值的數(shù)據(jù) */ @RequestMapping("/pageable") public void pageable(){ //Pageable是接口,PageRequest是接口實現(xiàn) //PageRequest的對象構造函數(shù)有多個,page是頁數(shù),初始值是0,size是查詢結果的條數(shù),后兩個參數(shù)參考Sort對象的構造方法 Pageable pageable = new PageRequest(0,3, Sort.Direction.DESC,"id"); Page<Customer> page = repository.findByName("bauer",pageable); //查詢結果總行數(shù) System.out.println(page.getTotalElements()); //按照當前分頁大小,總頁數(shù) System.out.println(page.getTotalPages()); //按照當前頁數(shù)、分頁大小,查出的分頁結果集合 for (Customer customer: page.getContent()) { System.out.println(customer.toString()); } System.out.println("-------------------------------------------"); }
從示例代碼的注釋當中可以看到Page對象的相關參數(shù)及值的說明,更詳細的用法,參考PageRequest源碼。
小結:怎么樣,是不是很簡單很方便?!
參考:
官方文檔,http://docs.spring.io/spring-data/jpa/docs/current/reference/html/
DEMO,https://github.com/icnws/spring-data-jpa-demo
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
spring boot+thymeleaf+bootstrap實現(xiàn)后臺管理系統(tǒng)界面
這篇文章主要為大家詳細介紹了spring boot+thymeleaf+bootstrap簡單實現(xiàn)后臺管理系統(tǒng)界面,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12java?LockSupport實現(xiàn)原理示例解析
這篇文章主要為大家介紹了java?LockSupport實現(xiàn)原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01如何利用Java8 Stream API對Map按鍵或值排序
這篇文章主要給大家介紹了關于如何利用Java8 Stream API對Map按鍵或值排序的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Java8具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-11-11MyBatis使用注解開發(fā)和無主配置文件開發(fā)的情況
這篇文章主要介紹了MyBatis使用注解開發(fā)和無主配置文件開發(fā)的情況,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03spring boot 統(tǒng)一JSON格式的接口返回結果的實現(xiàn)
這篇文章主要介紹了spring boot 統(tǒng)一JSON格式的接口返回結果的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10