使用SpringData+JPA的@Query注解完成动态条件分页查询
欢迎来到阿八个人博客网站。本 阿八个人博客 网站提供最新的站长新闻,各种互联网资讯。 喜欢本站的朋友可以收藏本站,或者加QQ:我们大家一起来交流技术! URL链接:https://www.abboke.com/jsh/2019/0717/8719.html 1190000019782020
写作原因
之前在学校都是做前端,但是最后找了个Java后端的工作,框架什么的基本没用过,所以工作中遇到了很多问题,所以决定记录下来工作中遇到的问题,记录成长的点滴。
正文
公司使用的是现在流行的SpringBoot,数据库方面使用的是SpringData+JPA+Hibernate。这几天用的最多的就是用JPA进行查询了,简单的查询很简单,网上查一查就有一堆方案,直到遇到分页查询的时候出了问题。
网上查到的大多都是使用EntityManager通过人工拼接sql来查询的,但是今天从导师那里学到了一手,在Repository中使用@Query注解即可。
代码如下
public interface StudentRepository extends JpaRepository<Student,Integer> {
@Query(
value = "SELECT * FROM student"
+ " WHERE (age = ?1 OR ?1 IS NULL)"
+ " WHERE (id = ?2 OR ?2 IS NULL)"
+ " WHERE (first_name = ?3 OR ?3 IS NULL)"
+ " ORDER BY ?#{#pageable}",
countQuery = "SELECT COUNT(1) FROM "
+ "SELECT * FROM student"
+ " WHERE (age = ?1 OR ?1 IS NULL)"
+ " WHERE (id = ?2 OR ?2 IS NULL)"
+ " WHERE (first_name = ?3 OR ?3 IS NULL)"
+ " ORDER BY ?#{#pageable}",
nativeQuery = true
)
Page<Student> findByAgeAndIdAndFirstName(Integer age, Integer id, String firstName, Pageable pageable);
}
最后的Pageable
可以使用PageRequest
来创建。
这里其实主要还是使用了SQL的语法,SQL还是有很多需要去学的。