首頁技術(shù)文章正文

如何使用Spring Boot實現(xiàn)分頁和排序?

更新時間:2023-04-26 來源:黑馬程序員 瀏覽量:

IT培訓班

  使用Spring Boot實現(xiàn)分頁和排序需要借助Spring Data JPA。Spring Data JPA是Spring Data項目中的一個模塊,提供了簡化數(shù)據(jù)訪問層的功能,包括分頁和排序。

  接下來我們通過一段Java代碼,展示如何使用Spring Data JPA和Spring Boot實現(xiàn)分頁和排序:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort;
import org.springframework.stereotype.Service;

@Service
public class UserService {
  
  @Autowired
  private UserRepository userRepository;
  
  public Page<User> getUsers(int pageNumber, int pageSize, String sortBy) {
    PageRequest pageRequest = PageRequest.of(pageNumber, pageSize, Sort.by(sortBy));
    return userRepository.findAll(pageRequest);
  }
  
}

  上面的代碼展示了一個UserService,其中有一個getUsers方法,該方法接受三個參數(shù):頁碼、頁大小和排序?qū)傩?。該方法使用Spring Data JPA的findAll方法,該方法使用PageRequest對象進行分頁和排序設(shè)置。在本例中,使用Sort.by方法設(shè)置了排序?qū)傩浴?br/>

1682474520327_SpringBoot實現(xiàn)分頁和排序.jpg

  在UserRepository中,只需要繼承JpaRepository,不需要實現(xiàn)任何方法,因為Spring Data JPA會為我們自動生成CRUD方法。

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

@Repository
public interface UserRepository extends JpaRepository<User, Long> {

}

  上面的代碼展示了UserRepository,其中繼承了JpaRepository,它提供了許多常用的CRUD方法。

  在使用時,我們可以像下面這樣調(diào)用UserService的getUsers方法:

@RestController
public class UserController {

  @Autowired
  private UserService userService;

  @GetMapping("/users")
  public Page<User> getUsers(@RequestParam("page") int pageNumber,
                             @RequestParam("size") int pageSize,
                             @RequestParam("sort") String sortBy) {
    return userService.getUsers(pageNumber, pageSize, sortBy);
  }
  
}

  上面的代碼展示了一個UserController,它使用GET請求處理/users路徑,并調(diào)用UserService的getUsers方法來獲取用戶列表。在請求參數(shù)中,我們可以傳遞頁碼、頁大小和排序?qū)傩浴?/p>

  以上就是一個基本的Spring Boot分頁和排序示例,希望可以幫助大家了解如何使用Spring Boot實現(xiàn)分頁和排序。

分享到:
在線咨詢 我要報名
和我們在線交談!