2

У меня есть приложение Spring boot 1.4.2 с Hibernate 5.2.6 и данными Spring Envers 1.0.5. Я проверяю свои сущности, и записи аудита сохраняются должным образом.Spring Data Envers org.springframework.data.mapping.PropertyReferenceException: нет свойства findRevisions найдено для типа

Мой класс конфигурации приложения аннотирован для использования EnversRevisionRepositoryFactoryBean.class в качестве фабрики репозитория JPA.

конфигурации Применение

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

Я пытаюсь прочитать пересмотры для аудируемого лица. Репозиторий объектов расширяет RevisionRepository.

Entity Модели

@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 хранилище

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

    foo findById(Long Id); 

    foo findByBarId(Long barId); 

} 

Приложение запуска вверх терпит неудачу как хранилище не может быть инициализирован из-за PropertyReferenceException.

не Вызванный: org.springframework.data.mapping.PropertyReferenceException: Нет собственности findRevisions найдено для типа Foo! на org.springframework.data.mapping.PropertyPath. (PropertyPath.java:77) в org.springframework.data.mapping.PropertyPath.create (PropertyPath.java:329) на org.springframework.data. mapping.PropertyPath.create (PropertyPath.java:309) на org.springframework.data.mapping.PropertyPath.from (PropertyPath.java:272) на org.springframework.data.mapping.PropertyPath.from (PropertyPath. Java: 243) на org.springframework.data.repository.query.parser.Part (Part.java:76) в org.springframework.data.repository.query.parser.PartTree $ OrPart (PartTree... java: 235) на org.springframework.data.repository.query.parser.PartTree $ Predicate.buildTree (PartTree.java:373) в org.springframework.data.repository.query.parser.PartTree $ предиката. (PartTree.java : 353) на org.springframework.data.repository.query.parser.PartTree (PartTree.java:84) на org.springframework.data.jpa.repository.query.PartTreeJpaQuery (PartTreeJpaQuery.java:63..) на org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy $ CreateQueryLookupStrategy.resolveQuery (JpaQueryLookupStrategy.java:103) в org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy $ CreateIfNotFoundQueryLookupStrategy.resolveQuery (JpaQueryLookupStrategy.java:214) на org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy $ AbstractQueryLookupStrategy.resolveQuery (JpaQueryLookupStrategy.java:77) в org.springframework.data.repository.core.support.RepositoryFactorySupport $ QueryExecutorMethodInterceptor. (RepositoryFactorySupport.java:435) в org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository (RepositoryFactorySupport.java:220) в org.springframework.data.repository.core.support. RepositoryFactoryBeanSupport.initAndReturn (RepositoryFactoryBeanSupport.Java: 266) на org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.afterPropertiesSet (RepositoryFactoryBeanSupport.java:252) на org.springframework.data.jpa.repository.support.JpaRepositoryFactoryBean.afterPropertiesSet (JpaRepositoryFactoryBean. Java: 92) на org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods (AbstractAutowireCapableBeanFactory.java:1642) на org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean (AbstractAutowireCapableBeanFactory.java:1579)

Из того, что я понимаю, это должно работать из коробки. Кажется, что репозиторий связан с другой реализацией, чем с желаемой. Есть идеи?

Соответствующие фрагменты из Gradle сценария сборки

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" 
) 

Спасибо заранее.

+0

Может включать вашу 'модель лица Foo' пожалуйста? – Naros

+0

@Naros, я редактировал свое сообщение, чтобы добавить модель сущности. Похоже, что Spring интерпретирует методы RevisionRepository для автоматического генерирования запросов кандидатов для свойств сущностей вместо привязки методов реализации интерфейса? – golfradio

+0

Можете ли вы подтвердить, что у вас есть версия '5.2.6.Final' артефакта' hibernate-envers' на пути к классам, а не старше? – Naros

ответ

3

Вам нужно добавить атрибут @EnableJpaRepositories(repositoryFactoryBeanClass = EnversRevisionRepositoryFactoryBean.class) в прикладном классе (класс с аннотацией @SpringBootApplication)

Как показано в этом ответе: https://stackoverflow.com/a/36416266

+0

Спасибо, но если вы видите мой оригинальный пост, у меня уже есть эта аннотация. Не помогло. – golfradio

Смежные вопросы