• <bdo id='GfSMh'></bdo><ul id='GfSMh'></ul>
  • <legend id='GfSMh'><style id='GfSMh'><dir id='GfSMh'><q id='GfSMh'></q></dir></style></legend>
    <i id='GfSMh'><tr id='GfSMh'><dt id='GfSMh'><q id='GfSMh'><span id='GfSMh'><b id='GfSMh'><form id='GfSMh'><ins id='GfSMh'></ins><ul id='GfSMh'></ul><sub id='GfSMh'></sub></form><legend id='GfSMh'></legend><bdo id='GfSMh'><pre id='GfSMh'><center id='GfSMh'></center></pre></bdo></b><th id='GfSMh'></th></span></q></dt></tr></i><div id='GfSMh'><tfoot id='GfSMh'></tfoot><dl id='GfSMh'><fieldset id='GfSMh'></fieldset></dl></div>
    1. <tfoot id='GfSMh'></tfoot>

        <small id='GfSMh'></small><noframes id='GfSMh'>

        具有任意 AND 子句的动态 spring 数据 jpa 存储库查询

        时间:2024-08-24

        <legend id='9IuGu'><style id='9IuGu'><dir id='9IuGu'><q id='9IuGu'></q></dir></style></legend>
      1. <small id='9IuGu'></small><noframes id='9IuGu'>

            <i id='9IuGu'><tr id='9IuGu'><dt id='9IuGu'><q id='9IuGu'><span id='9IuGu'><b id='9IuGu'><form id='9IuGu'><ins id='9IuGu'></ins><ul id='9IuGu'></ul><sub id='9IuGu'></sub></form><legend id='9IuGu'></legend><bdo id='9IuGu'><pre id='9IuGu'><center id='9IuGu'></center></pre></bdo></b><th id='9IuGu'></th></span></q></dt></tr></i><div id='9IuGu'><tfoot id='9IuGu'></tfoot><dl id='9IuGu'><fieldset id='9IuGu'></fieldset></dl></div>
            • <tfoot id='9IuGu'></tfoot>
                <bdo id='9IuGu'></bdo><ul id='9IuGu'></ul>
                  <tbody id='9IuGu'></tbody>
                • 本文介绍了具有任意 AND 子句的动态 spring 数据 jpa 存储库查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在使用 Spring data jpa repositories,需要提供具有不同字段的搜索功能.在搜索之前输入字段是可选的.我有 5 个字段,分别是 EmployeeNumberNameMarriedProfession出生日期.
                  这里我只需要查询用户给定的值,其他字段应该被忽略.例如,

                  I'm using Spring data jpa repositories, Got a requirement to give search feature with different fields. Entering fields before search is optional.I have 5 fields say EmployeeNumber, Name, Married,Profession and DateOfBirth.
                  Here i need to query only with the given values by user and other fields should be ignored.Ex,

                  Input : EmployeeNumber: ,Name:St,Married: ,Professsion:IT,DateOfBirth: 
                  Query : Select * from Employee e where Name like 'St%' and Profession like 'IT%';  
                  
                  Input : EmployeeNumber:10,Name: ,Married: ,Professsion:IT,DateOfBirth:
                  Query : Select * from Employee e where EmployeeNumber like '10%' and Profession like 'IT%';  
                  

                  所以这里我们考虑输入和查询的值.在这种情况下,Spring 数据有一个限制,如 这篇文章(不可扩展,所有可能的查询都应该写)我正在使用 Querydsl,但问题仍然存在,因为应该忽略 null 字段并且需要开发几乎所有可能的查询.在这个 case 31 查询 中.如果搜索字段是 6,7,8... 怎么办??

                  So here we are considering values entered and querying. In this case, Spring data is having a limitation as mentioned in this post (Not scalable and all possible queries should be written) I'm using Querydsl, but still the problem exists as null fields should be ignored and almost all possible queries need to be developed. In this case 31 queries. what if search fields are 6,7,8... ??

                  使用可选字段实现搜索选项的最佳方法是什么?

                  推荐答案

                  请注意,使用新的主要版本 QueryDSL (4.x) 和 querydsl-jpa

                  Please note that there might be changes to be done to use the new major version of QueryDSL (4.x) and querydsl-jpa

                  在我们的一个项目中,我们使用 QueryDSLQueryDslPredicateExecutor.

                  In one of our projects, we used QueryDSL with QueryDslPredicateExecutor<T>.

                    public Predicate createPredicate(DataEntity dataEntity) {
                      QDataEntity qDataEntity = QDataEntity.dataEntity;
                      BooleanBuilder booleanBuilder = new BooleanBuilder();
                      if (!StringUtils.isEmpty(dataEntity.getCnsiConsumerNo())) {
                        booleanBuilder
                          .or(qDataEntity.cnsiConsumerNo.contains(dataEntity.getCnsiConsumerNo()));
                      }
                      if (!StringUtils.isEmpty(dataEntity.getCnsiMeterNo())) {
                        booleanBuilder.or(qDataEntity.cnsiMeterNo.contains(dataEntity.getCnsiMeterNo()));
                      }
                  
                      return booleanBuilder.getValue();
                    }
                  

                  我们可以在存储库中使用它:

                  And we could use this in the repositories:

                  @Repository
                  public interface DataEntityRepository
                    extends DaoRepository<DataEntity, Long> {
                  

                  DaoRepository 在哪里

                  @NoRepositoryBean
                  public interface DaoRepository<T, K extends Serializable>
                    extends JpaRepository<T, K>,
                    QueryDslPredicateExecutor<T> {
                  }
                  

                  因此,您可以使用存储库谓词方法.

                  Because then, you can use repository predicate methods.

                  Iterable<DataEntity> results = dataEntityRepository.findAll(dataEntityPredicateCreator.createPredicate(dataEntity));
                  

                  要获取 QClasses,您需要指定 QueryDSL APT Maven 插件 在你的 pom.xml 中.

                  To get QClasses, you need to specify the QueryDSL APT Maven plugin in your pom.xml.

                    <build>
                      <plugins>
                        <plugin>
                          <groupId>com.mysema.maven</groupId>
                          <artifactId>maven-apt-plugin</artifactId>
                          <version>1.0.4</version>
                          <executions>
                            <execution>
                              <phase>generate-sources</phase>
                              <goals>
                                <goal>process</goal>
                              </goals>
                              <configuration>
                                <outputDirectory>target/generated-sources</outputDirectory>
                                <processor>com.mysema.query.apt.jpa.JPAAnnotationProcessor</processor>
                              </configuration>
                            </execution>
                          </executions>
                        </plugin>
                  

                  依赖是

                      <!-- querydsl -->
                      <dependency>
                          <groupId>com.mysema.querydsl</groupId>
                          <artifactId>querydsl-core</artifactId>
                          <version>${querydsl.version}</version>
                      </dependency>
                      <dependency>
                          <groupId>com.mysema.querydsl</groupId>
                          <artifactId>querydsl-apt</artifactId>
                          <version>${querydsl.version}</version>
                      </dependency>
                      <dependency>
                          <groupId>com.mysema.querydsl</groupId>
                          <artifactId>querydsl-jpa</artifactId>
                          <version>${querydsl.version}</version>
                      </dependency>
                  

                  或者对于 Gradle:

                  Or for Gradle:

                  sourceSets {
                      generated
                  }
                  sourceSets.generated.java.srcDirs = ['src/main/generated']
                  configurations {
                      querydslapt
                  }
                  dependencies {
                      // other deps ....
                      compile "com.mysema.querydsl:querydsl-jpa:3.6.3"
                      compile "com.mysema.querydsl:querydsl-apt:3.6.3:jpa"
                  }
                  task generateQueryDSL(type: JavaCompile, group: 'build', description: 'Generates the QueryDSL query types') {
                      source = sourceSets.main.java
                      classpath = configurations.compile + configurations.querydslapt
                      options.compilerArgs = [
                              "-proc:only",
                              "-processor", "com.mysema.query.apt.jpa.JPAAnnotationProcessor"
                      ]
                      destinationDir = sourceSets.generated.java.srcDirs.iterator().next()
                  }
                  
                  compileJava {
                      dependsOn generateQueryDSL
                      source generateQueryDSL.destinationDir
                  }
                  
                  compileGeneratedJava {
                      dependsOn generateQueryDSL
                      classpath += sourceSets.main.runtimeClasspath
                  }
                  

                  这篇关于具有任意 AND 子句的动态 spring 数据 jpa 存储库查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  上一篇:在 IntelliJ 的 Java 项目中使用 .gdsl 文件 下一篇:Spring data jpa - 如何通过方法名称组合多个And和Or

                  相关文章

                • <small id='217d5'></small><noframes id='217d5'>

                  • <bdo id='217d5'></bdo><ul id='217d5'></ul>

                    <i id='217d5'><tr id='217d5'><dt id='217d5'><q id='217d5'><span id='217d5'><b id='217d5'><form id='217d5'><ins id='217d5'></ins><ul id='217d5'></ul><sub id='217d5'></sub></form><legend id='217d5'></legend><bdo id='217d5'><pre id='217d5'><center id='217d5'></center></pre></bdo></b><th id='217d5'></th></span></q></dt></tr></i><div id='217d5'><tfoot id='217d5'></tfoot><dl id='217d5'><fieldset id='217d5'></fieldset></dl></div>

                    1. <tfoot id='217d5'></tfoot>
                      <legend id='217d5'><style id='217d5'><dir id='217d5'><q id='217d5'></q></dir></style></legend>