springboot集成queryDSL并实现单表分页查询BooleanBuilder

源码地址:https://gitee.com/yk001/base.git

1,导入包

		<dependency>
			<groupId>com.querydsl</groupId>
			<artifactId>querydsl-jpa</artifactId>
			<version>4.4.0</version>
		</dependency>
		<dependency>
			<groupId>com.querydsl</groupId>
			<artifactId>querydsl-apt</artifactId>
			<version>4.4.0</version>
		</dependency>

如果包下载不下来,切换一下项目的repositories

	<repositories>
<!--		<repository>-->
<!--			<id>nexus-aliyun</id>-->
<!--			<name>Nexus aliyun</name>-->
<!--			<url>https://maven.aliyun.com/nexus/repository/public</url>-->
<!--		</repository>-->
		<repository>
			<id>nexus-aliyun-google</id>
			<name>Nexus aliyun google</name>
			<url>https://maven.aliyun.com/repository/google</url>
		</repository>
	</repositories>

2,导入插件

			<plugin>
				<groupId>com.mysema.maven</groupId>
				<artifactId>apt-maven-plugin</artifactId>
				<version>1.1.3</version>
				<executions>
					<execution>
						<goals>
							<goal>process</goal>
						</goals>
						<configuration>
							<outputDirectory>target/generated-sources/java</outputDirectory>
							<processor>com.querydsl.apt.jpa.JPAAnnotationProcessor</processor>
						</configuration>
					</execution>
				</executions>
			</plugin>

3,新增配置类

package com.yukang.base.config;

import com.querydsl.jpa.impl.JPAQueryFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import javax.persistence.EntityManager;


/**
 * Date:     2020/11/28 2:23 下午<br/>
 *
 * @author yukang
 */
@Configuration
public class DslJpaConfig {

    @Bean
    public JPAQueryFactory jpaQueryFactory(EntityManager entityManager){
        return new JPAQueryFactory(entityManager);
    }

}

4,*Repository接口继承QuerydslPredicateExecutor

public interface BaseEntityRepo extends JpaRepository<BaseEntity,Long>, QuerydslPredicateExecutor<BaseEntity> {

}

5,查询逻辑

    @GetMapping("/baseentity")
    public Page<BaseEntity> getBaseEntitys(
            @RequestParam(name="createdTime",required = false) Timestamp createdTime,
            @RequestParam(name="page",defaultValue = "0") Integer page,
            @RequestParam(name="size",defaultValue = "10")  Integer size) {
        QBaseEntity qBaseEntity = QBaseEntity.baseEntity;
        BooleanBuilder booleanBuilder = new BooleanBuilder(qBaseEntity.id.isNotNull());
        if(createdTime != null){
            booleanBuilder.and(qBaseEntity.createdTime.goe(createdTime));
        }
        //分页排序
        Sort sort = Sort.by(Sort.Direction.ASC,"id");
        PageRequest pageRequest = PageRequest.of(page,size,sort);
        return baseEntityRepo.findAll(booleanBuilder.getValue(),pageRequest);
    }

6,验证

page 从0开始

curl -X GET "http://localhost:9001/baseentity?page=0&size=2" -H "accept: */*"
{
  "content": [
    {
      "id": 1,
      "name": "string",
      "remark": {
        "additionalProp1": {},
        "additionalProp3": {},
        "additionalProp2": {}
      },
      "createdTime": "2020-11-29 14:34:59"
    },
    {
      "id": 2,
      "name": "string",
      "remark": {
        "additionalProp1": {},
        "additionalProp3": {},
        "additionalProp2": {}
      },
      "createdTime": "2020-11-29 14:37:15"
    }
  ],
  "pageable": {
    "sort": {
      "sorted": true,
      "unsorted": false,
      "empty": false
    },
    "pageNumber": 0,
    "pageSize": 2,
    "offset": 0,
    "paged": true,
    "unpaged": false
  },
  "totalPages": 2,
  "totalElements": 3,
  "last": false,
  "numberOfElements": 2,
  "number": 0,
  "sort": {
    "sorted": true,
    "unsorted": false,
    "empty": false
  },
  "size": 2,
  "first": true,
  "empty": false
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,目前还没有Spring Boot 3的版本发布,最新的版本是Spring Boot 2.5.4。QueryDSL是一个用于构建类型安全的SQL查询的框架,它可以与Spring Boot集成使用。在Spring Boot中使用QueryDSL可以方便地进行数据库查询操作,而不需要编写原生的SQL语句。 要在Spring Boot中使用QueryDSL,首先需要添加相关的依赖。在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.querydsl</groupId> <artifactId>querydsl-core</artifactId> <version>5.0.0</version> </dependency> <dependency> <groupId>com.querydsl</groupId> <artifactId>querydsl-jpa</artifactId> <version>5.0.0</version> </dependency> ``` 接下来,需要配置QueryDSL的插件,以生成Q类文件。在pom.xml文件中添加以下插件配置: ```xml <build> <plugins> <plugin> <groupId>com.mysema.maven</groupId> <artifactId>apt-maven-plugin</artifactId> <version>1.1.3</version> <executions> <execution> <goals> <goal>process</goal> </goals> <configuration> <outputDirectory>target/generated-sources/java</outputDirectory> <processor>com.querydsl.apt.jpa.JPAAnnotationProcessor</processor> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 然后,在你的实体类中使用QueryDSL的注解来定义查询条件。例如: ```java @Entity public class User { @Id private Long id; private String name; private Integer age; // getters and setters } ``` 接下来,运行`mvn clean compile`命令,生成Q类文件。 最后,在你的Repository接口中使用QueryDSL进行查询操作。例如: ```java @Repository public interface UserRepository extends JpaRepository<User, Long>, QuerydslPredicateExecutor<User> { } ``` 现在你可以在Service或Controller中使用UserRepository进行查询操作了。例如: ```java @Service public class UserService { @Autowired private UserRepository userRepository; public List<User> getUsersByName(String name) { QUser qUser = QUser.user; return (List<User>) userRepository.findAll(qUser.name.eq(name)); } } ``` 这样就可以根据name字段进行查询了。 希望以上信息对你有帮助!如果你还有其他问题,请继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值