在Spring Boot中,可以使用以下方法来实现分页查询:
Pageable
接口和Page
对象来实现分页查询。在Repository方法中,可以定义一个带有Pageable
参数的查询方法,并返回Page
对象。import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;
public interface UserRepository extends JpaRepository<User, Long> {
Page<User> findAll(Pageable pageable);
}
在Service或Controller中,可以通过调用Repository的查询方法来进行分页查询,并获取到分页结果:
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
@Service
public class UserService {
@Autowired
private UserRepository userRepository;
public Page<User> findAllUsers(int page, int size) {
PageRequest pageable = PageRequest.of(page, size);
return userRepository.findAll(pageable);
}
}
@Query
注解和JPQL语句来实现分页查询。可以在Repository接口中定义带有@Query
注解的查询方法,并在JPQL语句中使用LIMIT
和OFFSET
来限制查询结果的数量和偏移量。import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
public interface UserRepository extends JpaRepository<User, Long> {
@Query("SELECT u FROM User u")
Page<User> findAllUsers(Pageable pageable);
}
在Service或Controller中,同样可以通过调用Repository的查询方法来进行分页查询,并获取到分页结果。
以上是两种常用的Spring Boot分页查询方法,根据具体的业务需求和喜好可以选择适合的方法来实现分页查询。
辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
推荐阅读: springboot怎么读取外部配置文件