Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/haskell/8.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Postgresql 使用haschanged查询审核表时出错_Postgresql_Hibernate_Spring Boot_Hibernate Envers - Fatal编程技术网

Postgresql 使用haschanged查询审核表时出错

Postgresql 使用haschanged查询审核表时出错,postgresql,hibernate,spring-boot,hibernate-envers,Postgresql,Hibernate,Spring Boot,Hibernate Envers,我有一个模板实体,它有: @ManyToOne @JsonView(JsonDefinitionMapper.SecondLevel.class) @Audited private TemplateType templateType; 例如 当我要使用循环实体属性查询所有更改时,如下所示(属性由实体的元数据获取): 生成的模板AUD表具有模板类型、模板类型和id列(自动生成) 运行上述查询时,我遇到此错误: org.hibernate.QueryException

我有一个模板实体,它有:

@ManyToOne
    @JsonView(JsonDefinitionMapper.SecondLevel.class)   
    @Audited
    private TemplateType templateType;
例如

当我要使用循环实体属性查询所有更改时,如下所示(属性由实体的元数据获取):

生成的模板AUD表具有模板类型、模板类型和id列(自动生成)

运行上述查询时,我遇到此错误:

org.hibernate.QueryException:无法解析属性:templateType of:com.templates.domain.Template\u AUD[从com.templates.domain.Template\u AUD e\u、com.Template.domain.AuditedRevisionEntity r中选择e\u.templateType\u MOD=:\u p0和e\u.originalId.id=:\u p1和e\u.originalId.REV.id=:\u p2和e\u.originalId.REV.id=r.id]
位于org.hibernate.QueryException.generateQueryException(QueryException.java:120)
在org.hibernate.QueryException.wrapWithQueryString(QueryException.java:103)
位于org.hibernate.hql.internal.ast.QueryTranslatorImpl.docomFile(QueryTranslatorImpl.java:218)
位于org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:142) 在org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:115) 在org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:76) 位于org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:150) 位于org.hibernate.internal.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:302) 位于org.hibernate.internal.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:240) 位于org.hibernate.internal.SessionImpl.createQuery(SessionImpl.java:1894) 位于org.hibernate.envers.internal.tools.query.QueryBuilder.toQuery(QueryBuilder.java:226) 位于org.hibernate.envers.query.internal.impl.AbstractAuditQuery.buildQuery(AbstractAuditQuery.java:79) 位于org.hibernate.envers.query.internal.impl.AbstractAuditQuery.buildAndExecuteQuery(AbstractAuditQuery.java:85) 位于org.hibernate.envers.query.internal.impl.RevisionsOfEntityQuery.list(RevisionsOfEntityQuery.java:108) 位于org.hibernate.envers.query.internal.impl.AbstractAuditQuery.getSingleResult(AbstractAuditQuery.java:97) 位于com.template.dataRepository.TemplateRevisionRepository.getAllChangedProperties with revisions(TemplateRevisionRepository.java:211) 在com.template.dataRepository.TemplateRevisionRepository$$FastClassBySpringCGLIB$$5bf5efd1.invoke()上 位于org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) 位于org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:720) 在org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:157)上 位于org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:136) 在org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:179)上 位于org.springframework.transaction.interceptor.TransactionInterceptor$1.proceedWithInvocation(TransactionInterceptor.java:99) 位于org.springframework.transaction.interceptor.TransactionSpectSupport.invokeWithinTransaction(TransactionSpectSupport.java:282) 位于org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96) 在org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:179)上 位于org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:655) 位于com.template.dataRepository.TemplateRevisionRepository$$EnhancerBySpringCGLIB$$952a9450.GetAllChangedProperties WithRevisions() 在com.template.EnversTest.getAllChangedProperties with revisions(EnversTest.java:151)上 在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处 位于sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中 位于java.lang.reflect.Method.invoke(Method.java:498) 位于org.junit.runners.model.FrameworkMethod$1.runReflectVeCall(FrameworkMethod.java:50) 位于org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 位于org.junit.runners.model.FrameworkMethod.invokeeexplosive(FrameworkMethod.java:47) 位于org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 位于org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75) 位于org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86) 位于org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84) 位于org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 位于org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:252) 位于org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:94) 位于org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 位于org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 位于org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 访问org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 位于org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 位于org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) 位于org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.e
for(String property:PropertiesList){
newValue = auditReader.createQuery()
                                            .forRevisionsOfEntity(Template.class, false, true)
                                            .addProjection(AuditEntity.property(property))
                                            .add(AuditEntity.property(property).hasChanged())
                                            .add(AuditEntity.id().eq(templateId))
                                            .add(AuditEntity.revisionNumber().eq(revisionNumber)).getSingleResult();
}
final List results = auditReader.createQuery()
  .forEntitiesModifiedAtRevision( Template.class, revNo )
  .traverseRelation( "templateType", JoinType.INNER )
    .addProjection( AuditEntity.selectEntity( false ) )
    .up()
  .add( AuditEntity.property( "templateType" ).hasChanged() )
  .getResultList();
final List results = auditReader.createQuery()
  .forEntitiesModifiedAtRevision( Template.class, revNo )
  .add( AuditEntity.property( propertyName ).hasChanged() )
  .getResultList();