spring-data-jpa封装 Specification 动态条件查询

Zuji-JPA官方文档地址

Spring 项目集成

如果你是 Spring 项目,请直接集成zuji-jpa依赖,spring boot和spring mvc项目均支持。

gradle

implementation 'top.spring-data-jpa:zuji-jpa:1.0.1'

maven

<dependency>
  <groupId>top.spring-data-jpa</groupId>
  <artifactId>zuji-jpa</artifactId>
  <version>1.0.1</version>
</dependency>

使用示例

spring data jpa使用演示
类似于mybatis-plus的条件构造器
动态条件查询 + or 嵌套条件+ 排序+ 分页

public Page<User> list(ReqUserListVO params) {
   Specification<User> spec = Specifications.where(e -> {
       if (!params.getUserType().equals(UserType.ALL)) {
           e.eq("userType", params.getUserType());
       }
       if (params.getUserName() != null) {
           e.contains("userName", params.getUserName());
       }
       if (params.getRange() != null) {
           e.eq("assigneeId", AuthHelper.currentUserId());
       }
       e.or(e2 -> {
           e2.eq("status", "1");
           e2.eq("status", "2");
       });
       e.eq("deleted", 0);
   });
   Sort sort = Sort.by("createTime").descending();
   return repository.findAll(spec, params.pageRequest(sort));
}

如果没有条件判断也可以写成这样,链式编程

public Page<Users> list(ReqUserListDTO params) {
   Specification<User> spec = Specifications.where(e -> {
       e.eq("userType", params.getUserType())
        .contains("userName", params.getUserName())
        .eq("assigneeId", AuthHelper.currentUserId())
        .or(e2 -> e2.eq("status", "1").eq("status", "2"))
        .eq("deleted", 0);
   });
   Sort sort = Sort.by("createTime").descending();
   return repository.findAll(spec, params.pageRequest(sort));
}

等同于sql

SELECT
	* 
FROM
	user
WHERE
	user_type = 'ADMIN' 
	AND user_name like "%admin%" 
	AND assignee_id = 11 
	AND ( status = 1 OR status = 2 ) 
	AND deleted = 0 
ORDER BY
	create_time DESC 
	LIMIT 0,10

基于spring data jap Specification 查询封装,封装精简 灵活 ,扩展性非常强。

如果有任何问题或想要更多交流,请加QQ群 758629787。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!关于Spring Data JPA的分页查询,您可以按照以下步骤进行操作: 1. 首先,确保您的项目中已经引入了Spring Data JPA依赖,以及相关的数据库驱动依赖。 2. 创建一个继承自JpaRepository的接口,用于定义您的数据访问操作。例如: ```java import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.stereotype.Repository; @Repository public interface UserRepository extends JpaRepository<User, Long> { // 在这里可以定义各种自定义的查询方法 } ``` 3. 在您的Service层或者Controller层注入该Repository,并使用其提供的分页方法进行查询。例如: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Page; import org.springframework.data.domain.PageRequest; import org.springframework.stereotype.Service; @Service public class UserService { @Autowired private UserRepository userRepository; public Page<User> getUsersByPage(int pageNum, int pageSize) { PageRequest pageRequest = PageRequest.of(pageNum, pageSize); return userRepository.findAll(pageRequest); } } ``` 在上述示例中,我们通过调用`userRepository.findAll(pageRequest)`方法实现了分页查询,并传入`PageRequest`对象来指定页码和每页大小。 4. 最后,在您的Controller层中使用该Service方法来处理分页查询请求,并将结果返回给前端。例如: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Page; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @RestController public class UserController { @Autowired private UserService userService; @GetMapping("/users") public Page<User> getUsersByPage(@RequestParam int pageNum, @RequestParam int pageSize) { return userService.getUsersByPage(pageNum, pageSize); } } ``` 在上述示例中,我们通过`@RequestParam`注解来接收前端传递的pageNum和pageSize参数,并调用UserService中的方法进行查询。 这样,您就可以使用Spring Data JPA进行分页查询了。希望能对您有所帮助!如果您还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值