首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Spring jpql查询

Spring jpql查询
EN

Stack Overflow用户
提问于 2017-06-27 15:34:43
回答 1查看 940关注 0票数 3

我想知道是否可以通过spring存储库执行jpql查询,并能够使用分页作为排序特性,因为它可以附带示例和规范。我想做这样的事情:

代码语言:javascript
复制
findAll(String jpql, Pageable pageable)

QueryByExampleExecutor接口,即声明:

代码语言:javascript
复制
findAll(Example<S> example, Pageable pageable);

JpaSpecificationExecutor接口声明:

代码语言:javascript
复制
Page<T> findAll(Specification<T> spec, Pageable pageable);
EN

回答 1

Stack Overflow用户

发布于 2017-06-27 16:10:23

根据春季数据文档,即使使用本机查询也应该是可能的。请看一下示例51:

代码语言:javascript
复制
public interface UserRepository extends JpaRepository<User, Long> {

  @Query(value = "SELECT * FROM USERS WHERE LASTNAME = ?1",
    countQuery = "SELECT count(*) FROM USERS WHERE LASTNAME = ?1",
    nativeQuery = true)
  Page<User> findByLastname(String lastname, Pageable pageable);
}

根据文档,排序似乎也是可能的

代码语言:javascript
复制
public interface UserRepository extends JpaRepository<User, Long> {

  @Query("select u from User u where u.lastname like ?1%")
  List<User> findByAndSort(String lastname, Sort sort);

  @Query("select u.id, LENGTH(u.firstname) as fn_len from User u where u.lastname like ?1%")
  List<Object[]> findByAsArrayAndSort(String lastname, Sort sort);
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44784377

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档