spring-data 存储库自定义查询

Posted

技术标签:

【中文标题】spring-data 存储库自定义查询【英文标题】:spring-data repository custom query 【发布时间】:2016-08-29 22:54:27 【问题描述】:

我正在使用带有 postgres 数据库的 Spring Boot 应用程序,但在启动时确实遇到了异常。

例外是:

Caused by: java.lang.AbstractMethodError: org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy$CreateIfNotFoundQueryLookupStrategy.resolveQuery(Ljava/lang/reflect/Method;Lorg/springframework/data/repository/core/RepositoryMetadata;Lorg/springframework/data/projection/ProjectionFactory;Lorg/springframework/data/repository/core/NamedQueries;)Lorg/springframework/data/repository/query/RepositoryQuery;
    at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.<init>(RepositoryFactorySupport.java:435) ~[spring-data-commons-1.12.1.RELEASE.jar:na]
    at org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository(RepositoryFactorySupport.java:220) ~[spring-data-commons-1.12.1.RELEASE.jar:na]
    at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.initAndReturn(RepositoryFactoryBeanSupport.java:266) ~[spring-data-commons-1.12.1.RELEASE.jar:na]
    at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.afterPropertiesSet(RepositoryFactoryBeanSupport.java:252) ~[spring-data-commons-1.12.1.RELEASE.jar:na]
    at org.springframework.data.jpa.repository.support.JpaRepositoryFactoryBean.afterPropertiesSet(JpaRepositoryFactoryBean.java:92) ~[spring-data-jpa-1.9.4.RELEASE.jar:na]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1637) ~[spring-beans-4.2.5.RELEASE.jar:4.2.5.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1574) ~[spring-beans-4.2.5.RELEASE.jar:4.2.5.RELEASE]

我尝试使用自定义查询创建存储库,如下所示:

public interface LastRunRepository extends PagingAndSortingRepository<LastRun, Long> 
    LastRun findFirst1OrderByStartDateDesc();

我的 LastRun 实体如下所示:

import javax.persistence.*;
import java.util.Date;

@Entity(name = "last_run")
public class LastRun 

    @Id
    @GeneratedValue(strategy= GenerationType.IDENTITY)
    private Long id;

    @Column(name="start_date", nullable = false)
    private Date startDate;

    public LastRun() 
    

    public LastRun(Date startDate) 
        this.startDate = startDate;
    

    public Long getId() 
        return id;
    

    public void setId(Long id) 
        this.id = id;
    

    public Date getStartDate() 
        return startDate;
    

    public void setStartDate(Date startDate) 
        this.startDate = startDate;
    

    @Override
    public String toString() 
        return "LastRun" +
                "id=" + id +
                ", startDate=" + startDate +
                '';
    

如果我只使用标准查询,如查找或保存,它就像一个魅力。但是一旦我定义了一个自定义查询,它就会抛出这个异常。

在 mvn dependency:tree 中,我可以看到我从 sprint-boot-starter-data-jpa 获得了 spring-data-jpa 1.9.4 版本。

+- org.springframework.boot:spring-boot-starter-data-jpa:jar:1.3.3.RELEASE:compile
[INFO] |  +- org.springframework.boot:spring-boot-starter-aop:jar:1.3.3.RELEASE:compile
[INFO] |  |  \- org.aspectj:aspectjweaver:jar:1.8.8:compile
[INFO] |  +- org.springframework.boot:spring-boot-starter-jdbc:jar:1.3.3.RELEASE:compile
[INFO] |  |  \- org.apache.tomcat:tomcat-jdbc:jar:8.0.32:compile
[INFO] |  |     \- org.apache.tomcat:tomcat-juli:jar:8.0.32:compile
[INFO] |  +- org.hibernate:hibernate-entitymanager:jar:4.3.11.Final:compile
[INFO] |  |  +- org.jboss.logging:jboss-logging-annotations:jar:1.2.0.Beta1:compile
[INFO] |  |  +- org.hibernate:hibernate-core:jar:4.3.11.Final:compile
[INFO] |  |  |  +- antlr:antlr:jar:2.7.7:compile
[INFO] |  |  |  \- org.jboss:jandex:jar:1.1.0.Final:compile
[INFO] |  |  +- dom4j:dom4j:jar:1.6.1:compile
[INFO] |  |  |  \- xml-apis:xml-apis:jar:1.0.b2:compile
[INFO] |  |  +- org.hibernate.common:hibernate-commons-annotations:jar:4.0.5.Final:compile
[INFO] |  |  +- org.hibernate.javax.persistence:hibernate-jpa-2.1-api:jar:1.0.0.Final:compile
[INFO] |  |  \- org.javassist:javassist:jar:3.18.1-GA:compile
[INFO] |  +- javax.transaction:javax.transaction-api:jar:1.2:compile
[INFO] |  +- org.springframework.data:spring-data-jpa:jar:1.9.4.RELEASE:compile
+- org.springframework.data:spring-data-commons:jar:1.12.1.RELEASE:compile

我正在使用最新版本的 spring-data-jpa 和 spring-data-commons。

所以,spring-data-commons:jar:1.12.1.RELEASE 和 spring-data-jpa:jar:1.9.4.RELEASE (spring-boot-starter-data-jpa:jar:1.3.3.RELEASE ),不兼容吗?

【问题讨论】:

看起来您正在使用不兼容的 jar 版本。 Spring Data Commons 1.12 是最新版本,而 Spring Data JPA 1.9 是之前的版本,它依赖于 commons 1.11。 谢谢,我更新了原来的问题,请看看 您使用的不是最新版本...1.9 不是最新版本,1.10 是...您可以发布您的 pom。 【参考方案1】:

我有同样的问题。我确认这是由于不兼容的 Spring 数据和 Spring Boot 依赖项造成的。

pom.xml 示例:

  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.3.5.RELEASE</version>
  </parent>

  <dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-elasticsearch</artifactId>
    <version>2.0.0.RELEASE</version>
  </dependency>

在上面的 pom 中,Eclipse 发出警告,覆盖管理版本 1.3.4.RELEASE,如果您启动应用程序,您将收到描述的异常。

您应该删除版本并使用与spring-boot-starter-parent 中给出的相同的依赖项:

  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.3.5.RELEASE</version>
  </parent>

  <dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-elasticsearch</artifactId>
  </dependency>

【讨论】:

【参考方案2】:

你必须像这样使用 LastRun findByStartDateDesc(Pageable pageable);

在 Pageable pageable 参数中,您可以将参数作为 new PageRequest(0,size) 传递 其中 size 代表你想要多少条记录。

【讨论】:

我猜方法名称不正确,它不起作用。可能存在一些兼容性问题,但首先检查'LastRun findFirst1OrderByStartDateDesc();'这也是不正确的。在运行时你就知道了。通过修复兼容性问题来尝试它,你仍然在运行时遇到异常@ M. Deinum

以上是关于spring-data 存储库自定义查询的主要内容,如果未能解决你的问题,请参考以下文章

无法执行 Spring-data Couchbase 查询

微信小程序|组件库自定义加载动画

如何使用本机库自定义项目选择器的背景颜色

SceneKit 与 Vuforia AR 库自定义模型

使用 LeanBack 支持库自定义 Android TV 界面

密钥库自定义路径的Gradlew问题