一、Pageable的概念
Pageable實現了分頁的概念,它是一個介面,提供了分頁的各種參數來進行查詢。通過它我們可以方便地實現數據的分頁查詢,例如在網頁數據展現或者手機APP上翻頁展示等。
public interface Pageable { int getPageNumber(); int getPageSize(); int getOffset(); Sort getSort(); boolean hasPrevious(); Pageable next(); Pageable previousOrFirst(); Pageable first(); }
Pageable中的方法比較簡單,主要用於獲取分頁的一些參數。其中getPageNumber()方法表示當前頁碼,getPageSize()表示每頁顯示記錄數,getOffset()表示偏移量,getSort()表示根據什麼屬性進行排序等等。
二、使用Pageable實現簡單分頁查詢
使用Pageable進行分頁查詢的方式,通常是通過數據持久化層框架的查詢函數調用。以JPA為例:
@Repository public interface UserRepository extends JpaRepository { Page findAll(Pageable pageable); }
在介面中定義的findAll()方法傳入的參數為Pageable類型,通過調用findAll()方法即可返回一個Page對象,該對象中封裝了一些分頁相關的信息,例如當前頁碼、總頁數、總記錄數、每頁顯示的記錄數等。
接下來我們可以在controller層進行調用,並處理返回值:
@RestController public class UserController { @Autowired private UserRepository userRepository; @GetMapping("/users") public Map getUsers(@RequestParam(name = "page", defaultValue = "0") int page, @RequestParam(name = "size", defaultValue = "10") int size) { Pageable pageable = PageRequest.of(page, size); Page users = userRepository.findAll(pageable); Map result = new HashMap(); result.put("users", users.getContent()); result.put("currentPage", users.getNumber()); result.put("totalPages", users.getTotalPages()); result.put("totalItems", users.getTotalElements()); return result; } }
在controller層我們實例化了一個Pageable對象,並根據前端傳遞的參數進行了分頁查詢,最後將分頁查詢的結果封裝到Map中返回給前端,提供給前端使用。
三、分頁排序
在分頁的過程中,經常需要對數據進行排序,我們可以通過Pageable介面提供的getSort()方法實現分頁排序。下面的例子中,我們對username屬性進行升序排序:
Pageable pageable = PageRequest.of(page, size, Sort.by("username").ascending());
類似的,如果我們需要對多個屬性進行排序,只需要在Sort.by()方法中添加多個Sort.Order即可。例如,以下代碼將先對username欄位進行升序排序,然後對age欄位進行降序排序:
Pageable pageable = PageRequest.of(page, size, Sort.by("username").ascending().and(Sort.by("age").descending()));
四、自定義分頁參數
除了默認提供的分頁參數,例如每頁顯示的記錄數、當前頁碼等,我們還可以通過實現Pageable介面來實現自定義的分頁參數。例如,我們可以實現以下代碼:
public class MyPageable implements Pageable { private int pageNo; private int pageSize; private String orderByColumn; private boolean isAsc; public MyPageable(int pageNo, int pageSize, String orderByColumn, boolean isAsc) { this.pageNo = pageNo; this.pageSize = pageSize; this.orderByColumn = orderByColumn; this.isAsc = isAsc; } @Override public int getPageNumber() { return pageNo; } @Override public int getPageSize() { return pageSize; } @Override public long getOffset() { return (long) (pageNo - 1) * pageSize; } @Override public Sort getSort() { return isAsc ? Sort.by(orderByColumn).ascending() : Sort.by(orderByColumn).descending(); } @Override public Pageable next() { return new MyPageable(pageNo + 1, pageSize, orderByColumn, isAsc); } @Override public Pageable previousOrFirst() { return pageNo 1; } }
自定義的MyPageable類實現了Pageable介面,並覆蓋了其所有方法。其中,我們可以實現自定義的分頁參數,例如orderByColumn屬性表示按照哪個欄位進行排序,isAsc表示是否是升序排列等。實現後,我們就可以直接使用new MyPageable()的方式來進行分頁查詢。
五、總結
總的來說,使用Pageable可以方便地實現數據的分頁查詢,減輕後端查詢處理的壓力,同時也可以帶來更好的用戶交互體驗。在使用Pageable進行分頁查詢的過程中,我們可以通過排序、自定義參數等方式來滿足不同的需求。
原創文章,作者:HNOTW,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/372907.html