Spring-Data-JPA的setMaxResults注解
Spring-Data-JPA,一个强大的JPA存储库抽象库,简化了Spring中的数据访问基于Java的应用程序。然而,使用注解设置查询返回的最大结果数一直是一个挑战。
Spring Data JPA 1.7.0 (Evans Release Train) 解决方案
中Spring Data JPA 1.7.0 及更高版本中,情况有所改善。您现在可以使用 Top 和 First 关键字来限制查询结果。例如:
findTop10ByLastnameOrderByFirstnameAsc(String lastname);
Spring Data 会自动将返回结果的数量限制为指定数量(如果省略,则默认为 1)。结果的排序变得至关重要,无论是通过 OrderBy 子句还是方法中的 Sort 参数。
在 Spring Data JPA 1.7.0 之前
在此增强之前,检索数据切片需要使用分页。 Spring Data 使用 Pageable 接口进行分页请求,并使用 Page 抽象进行结果处理。
实现存储库接口如下:
public interface UserRepository extends Repository<User, Long> { List<User> findByUsername(String username, Pageable pageable); }
使用该接口获取结果:
Pageable topTen = new PageRequest(0, 10); List<User> result = repository.findByUsername("Matthews", topTen);
如果需要上下文信息,请使用 Page 作为返回类型:
public interface UserRepository extends Repository<User, Long> { Page<User> findByUsername(String username, Pageable pageable); }
客户端代码可以利用此信息:
Pageable topTen = new PageRequest(0, 10); Page<User> result = repository.findByUsername("Matthews", topTen); Assert.assertThat(result.isFirstPage(), is(true));
使用 Page 作为返回type 触发计数投影查询执行以确定元素的总数。此外,为了保证稳定的结果,请始终在 PageRequest 中包含排序信息。
以上是如何在 Spring Data JPA 中使用注解限制查询结果?的详细内容。更多信息请关注PHP中文网其他相关文章!