2

Ich habe eine Spring Boot 1.4.2 Anwendung mit Hibernate 5.2.6 und Spring Daten Envers 1.0.5. Ich auditiere meine Entitäten und die Audit-Datensätze werden ordnungsgemäß beibehalten.Spring Data Envers org.springframework.data.mapping.PropertyReferenceException: Keine Eigenschaft findRevisions gefunden für Typ

Meine Anwendungskonfigurationsklasse ist mit Anmerkungen versehen, um die EnversRevisionRepositoryFactoryBean.class als JPA-Repository-Factory zu verwenden.

Anwendungskonfigurations

@Configuration 
@EnableAutoConfiguration 
@ComponentScan 
@EnableJpaRepositories(repositoryFactoryBeanClass = EnversRevisionRepositoryFactoryBean.class) 
@EnableTransactionManagement 
public class ApplicationConfig {} 

ich die Revisionen für eine geprüften Stelle zu lesen versuchen. Das Entitätsrepository erweitert das RevisionRepository.

Entity Models

@Entity(name = "Base") 
@Inheritance(strategy = InheritanceType.SINGLE_TABLE) 
@DiscriminatorColumn(name = "type", discriminatorType = DiscriminatorType.INTEGER) 
@Table(name = "BASE") 
@Audited 
public abstract class Base { 

    @Id 
    @GeneratedValue(generator = "baseSeq", strategy = GenerationType.SEQUENCE) 
    @SequenceGenerator(name = "baseSeq", sequenceName = "BASE_SEQ", allocationSize = 1) 
    @Column(name = "id", updatable = false, nullable = false) 
    private Long id; 

    @Column(name = "name", nullable = false) 
    private String name; 

    @Column(name = "name", nullable = false) 
    private long barId; 

    public Long getId() { 
    return id; 
    } 

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

    public String getName() { 
    return name; 
    } 

    public void setName(String name) { 
    this.name = name; 
    } 

    public long getBarId() { 
    return barId; 
    } 

    public void setBarId(long barId) { 
    this.barId = barId; 
    } 

    public abstract String getType(); 

} 

@Entity 
@DiscriminatorValue("1") 
@Audited 
@NamedQueries({ 
    @NamedQuery(
     name = "Foo.findById", 
     query = "select f from Base b where b.id = ?1"), 
    @NamedQuery(
     name = "Foo.findByBarId", 
     query = "select f from Base b where b.barId = ?1")}) 
public class Foo extends Base { 
    private String type = "Foo"; 

    @Override 
    public String getType() { 
     return type; 
    } 
} 

Entity Repository

interface FooRepository extends JpaRepository<Foo, Long>, 
    JpaSpecificationExecutor<Foo>, RevisionRepository<Foo, Long, Integer> { 

    foo findById(Long Id); 

    foo findByBarId(Long barId); 

} 

Die Anwendung startet nicht wie das Repository kann nicht aufgrund eines PropertyReferenceException initialisiert werden.

Verursacht durch: org.springframework.data.mapping.PropertyReferenceException: Keine Eigenschaft findRevisions für Typ Foo gefunden! bei org.springframework.data.mapping.PropertyPath. (PropertyPath.java:77) bei org.springframework.data.mapping.PropertyPath.create (PropertyPath.java:329) bei org.springframework.data. mapping.PropertyPath.create (PropertyPath.java:309) bei org.springframework.data.mapping.PropertyPath.from (PropertyPath.java:272) bei org.springframework.data.mapping.PropertyPath.from (PropertyPath. java: 243) um org.springframework.data.repository.query.parser.Part. (Part.java:76) um org.springframework.data.repository.query.parser.PartTree $ OrPart. (PartTree. Java: 235) bei org.springframework.data.repository.query.parser.PartTree $ Predicate.buildTree (PartTree.java:373) bei org.springframework.data.repository.query.parser.PartTree $ Prädikat. (PartTree.java : 353) bei org.springframework.data.repository.query.parser.PartTree (PartTree.java:84) bei org.springframework.data.jpa.repository.query.PartTreeJpaQuery (PartTreeJpaQuery.java:63..) bei org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy $ CreateQueryLookupStrategy.resolveQuery (JpaQueryLookupStrategy.java:103) bei org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy $ CreateIfNotFoundQueryLookupStrategy.resolveQuery (JpaQueryLookupStrategy.java:214) bei org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy $ AbstractQueryLookupStrategy.resolveQuery (JpaQueryLookupStrategy.java:77) bei org.springframework.data.repository.core.support.RepositoryFactorySupport $ QueryExecutorMethodInterceptor. (RepositoryFactorySupport.java:435) bei org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository (RepositoryFactorySupport.java:220) bei org.springframework.data.repository.core.support. RepositoryFactoryBeanSupport.initAndReturn (RepositoryFactoryBeanSupport.Java: 266) bei org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.afterPropertiesSet (RepositoryFactoryBeanSupport.java:252) bei org.springframework.data.jpa.repository.support.JpaRepositoryFactoryBean.afterPropertiesSet (JpaRepositoryFactoryBean. Java: 92) bei org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods (AbstractAutowireCapableBeanFactory.java:1642) bei org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean (AbstractAutowireCapableBeanFactory.java:1579)

Von dem, was ich verstehe, sollte dies out-of-the-box funktionieren. Es scheint, dass das Repository an eine andere Implementierung als die gewünschte gebunden ist. Irgendwelche Ideen?

Relevante Auszüge aus dem gradle Build-Skript

buildscript { 
    ext { 
     springBootVersion = "1.4.2.RELEASE" 
     verifier_version = "1.0.0.RELEASE" 
    } 
    repositories { 
     maven {url "https://plugins.gradle.org/m2/"} 
     maven {url "http://repo.spring.io/plugins-release"} 
     jcenter() 
     mavenCentral() 
    } 
    dependencies { 
     classpath("org.springframework.build.gradle:propdeps-plugin:0.0.7") // this enables optional dependencies 
     classpath("io.spring.gradle:dependency-management-plugin:0.6.1.RELEASE") 
     classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") 
     classpath("se.transmode.gradle:gradle-docker:1.2") 
     classpath("com.commercehub:gradle-cucumber-jvm-plugin:0.7") 
     classpath("org.ajoberstar:grgit:1.1.0") 
     classpath("org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:2.1-rc3") 
     classpath("gradle.plugin.org.detoeuf:swagger-codegen-plugin:1.6.3") 
     classpath("org.springframework.cloud:spring-cloud-contract-gradle-plugin:${verifier_version}") 
     classpath "net.linguica.gradle:maven-settings-plugin:0.5" 
    } 
} 
... 
dependencyManagement { 
    imports { 
     mavenBom "org.springframework.cloud:spring-cloud-dependencies:Brixton.SR7" 
     mavenBom "org.springframework.cloud:spring-cloud-contract-dependencies:${verifier_version}" 
     mavenBom 'org.springframework.cloud:spring-cloud-stream-dependencies:Brooklyn.SR1' 
    } 
} 
... 
compile(
     "org.springframework.boot:spring-boot-starter-data-jpa", 
     'org.springframework.data:spring-data-commons',  
     'org.springframework.cloud:spring-cloud-starter-config', 
     'org.springframework.cloud:spring-cloud-starter-eureka', 
     'org.springframework.cloud:spring-cloud-starter-sleuth', 
     'org.springframework.cloud:spring-cloud-sleuth-zipkin', 
     'com.netflix.hystrix:hystrix-javanica',     
     'org.springframework.boot:spring-boot-starter-aop',  
     "org.springframework.boot:spring-boot-starter-web", 
     "io.swagger:swagger-annotations:1.5.9", 
     "com.google.code.gson:gson:2.7", 
     "gradle.plugin.org.detoeuf:swagger-codegen-plugin:1.6.3", 
     "org.springframework:spring-orm", 
     "com.oracle.jdbc:ojdbc7:12.1.0.2", 
     'org.springframework.cloud:spring-cloud-stream', 
     'org.springframework.cloud:spring-cloud-stream-test-support', 
     'org.springframework.cloud:spring-cloud-stream-binder-test', 
     "org.springframework.boot:spring-boot-starter-hateoas", 
     "com.fasterxml.jackson.module:jackson-module-parameter-names", 
     "com.fasterxml.jackson.datatype:jackson-datatype-jdk8", 
     "com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.6.1", 
     "org.hibernate:hibernate-core:5.2.6.Final", 
     "org.hibernate:hibernate-envers:5.2.6.Final", 
     "org.springframework.data:spring-data-envers:1.0.6.RELEASE" 
) 

Vielen Dank im Voraus.

+0

Kann Ihr 'foo' Entitätsmodell umfassen bitte? – Naros

+0

@Naros, Ich habe meinen Beitrag bearbeitet, um das Entitätsmodell hinzuzufügen. Offenbar interpretiert Spring die RevisionRepository-Methoden als automatisch generierte Abfragekandidaten für Entitätseigenschaften, anstatt die Schnittstellenimplementierungsmethoden zu binden. – golfradio

+0

Können Sie bestätigen, dass Sie die Version '5.2.6.Final' des' hibernate-envers'-Artefakts auf dem Klassenpfad haben und nicht älter? – Naros

Antwort

3

Sie benötigen ein Attribut @EnableJpaRepositories(repositoryFactoryBeanClass = EnversRevisionRepositoryFactoryBean.class) zu Ihrer Anwendungsklasse (die Klasse mit @SpringBootApplication kommentierten)

hinzufügen Wie es in dieser Antwort gezeigt: https://stackoverflow.com/a/36416266

+0

Danke, aber wenn Sie meinen ursprünglichen Post sehen, habe ich diese Annotation bereits. Hat nicht geholfen. – golfradio

Verwandte Themen