1

Spring 3.1、Spring data jpa 1.2、Hibernate 3.5.1、envers 3.5.1 を使用しています。この問題は、envers を使用すると _AUD テーブルが作成されますが、データが AUD テーブルに挿入されないことです。Personエンティティで@Auditedを使用し、RevListenerクラスを作成してRevisionListenerを実装しました。また、envers doc に記載されているように、DefaultRevisionEntity を拡張する RevEntity を作成しました。@Rollback(false) を使用し、PersonRepository 保存メソッドを使用するだけで、Spring Junit テストを実行しようとすると。データベースに新しい人物を保存していますが、Person_AUD テーブルには何も挿入されていません。以下は、私の春の設定ファイルからのスニペットです。

<bean id="atomikosTransactionManager"   class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init"
                    destroy-method="close">
                    <property name="forceShutdown" value="true" />
                    <property name="startupTransactionService" value="true" />

            </bean> 
<bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp">
            <property name="transactionTimeout" value="1000" />
            </bean>
<bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
                <property name="transactionManager" ref="atomikosTransactionManager" />
                <property name="userTransaction" ref="atomikosUserTransaction" />
                <property name="transactionSynchronizationName"  value="SYNCHRONIZATION_ON_ACTUAL_TRANSACTION" />
            </bean>

            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" id="PPL_GMRJPAVendorAdapter">
                    <property name="showSql" value="true"/>
                    <property name="generateDdl" value="true"/> 
                    <property name="databasePlatform" value="org.hibernate.dialect.Oracle10gDialect"/>
            </bean>

            <bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="PPL_GMR">
                    <property name="dataSource" ref="PPL_GMRDS"></property>
                    <property name="persistenceUnitName" value="PPL_GMR"/>
                    <property name="persistenceXmlLocation" value="classpath:META-INF/persistence-test.xml"/>
                    <property name="jpaVendorAdapter" ref="PPL_GMRJPAVendorAdapter"/>
                    <property name="jpaPropertyMap">
                            <map>
                                <entry key="hibernate.transaction.manager_lookup_class"                                                     



                        value="com.atomikos.icatch.jta.hibernate3.TransactionManagerLookup"/> 
                                        <entry key="hibernate.default_schema" value="${PPL.schema}"/>
                                <entry key="hibernate.hbm2ddl.auto" value="update"/>
                                <entry key="org.hibernate.envers.auditTablePrefix" value=""/>
                                <entry key="org.hibernate.envers.auditTableSuffix" value="_AUD"/>

                                <entry key="hibernate.transaction.flush_before_completion" value="false"/>
                                    <entry key="hibernate.transaction.auto_close_session" value="true"/>
                                    <entry key="hibernate.current_session_context_class" value="jta"/>
                                    <entry key="hibernate.connection.release_mode" value="auto"/>

                            </map>
                    </property>
            </bean>

ここに私のpersistence.xmlからの抜粋があります

<properties>
    <property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect"/>
     <property name="hibernate.ejb.event.post-insert"
             value="org.hibernate.ejb.event.EJB3PostInsertEventListener,org.hibernate.envers.event.AuditEventListener" />
          <property name="hibernate.ejb.event.post-update"
             value="org.hibernate.ejb.event.EJB3PostUpdateEventListener,org.hibernate.envers.event.AuditEventListener" />
          <property name="hibernate.ejb.event.post-delete"
             value="org.hibernate.ejb.event.EJB3PostDeleteEventListener,org.hibernate.envers.event.AuditEventListener" />
          <property name="hibernate.ejb.event.pre-collection-update"
             value="org.hibernate.envers.event.AuditEventListener" />
          <property name="hibernate.ejb.event.pre-collection-remove"
             value="org.hibernate.envers.event.AuditEventListener" />
          <property name="hibernate.ejb.event.post-collection-recreate"
             value="org.hibernate.envers.event.AuditEventListener" />             
    </properties> 
</persistence>

また、このプロパティを entitymanager config "hibernate.transaction.factory_class"value="com.atomikos.icatch.jta.hibernate3.AtomikosJTATransactionFactory" に追加しようとしましたが、これを追加した後、データは person テーブルにも挿入されません。また、AUD テーブルには通常のデータが挿入されません。作成された Person オブジェクトは表示されますが、コミットされません。

これは、デバッグ モードでのログの最後の数行です。

2013-04-03 11:47:39 DEBUG AbstractEntityManagerImpl:990 - Looking for a JTA transaction to join
2013-04-03 11:47:39 WARN  AbstractEntityManagerImpl:1099 - Cannot join transaction: do not override hibernate.transaction.factory_class
2013-04-03 11:47:40 DEBUG TransactionalRepositoryProxyPostProcessor$CustomAnnotationTransactionAttributeSource:288 - Adding transactional method 'save' with attribute: PROPAGATION_REQUIRED,ISOLATION_DEFAULT; ''
2013-04-03 11:47:40 DEBUG JDBCContext:199 - successfully registered Synchronization
2013-04-03 11:47:40 DEBUG SessionImpl:257 - opened session at timestamp: 13650040606
2013-04-03 11:47:40 DEBUG AbstractEntityManagerImpl:990 - Looking for a JTA transaction to join
2013-04-03 11:47:40 WARN  AbstractEntityManagerImpl:1099 - Cannot join transaction: do not override hibernate.transaction.factory_class
2013-04-03 11:47:40 DEBUG AbstractBatcher:410 - about to open PreparedStatement (open PreparedStatements: 0, globally: 0)
2013-04-03 11:47:40 DEBUG ConnectionManager:444 - opening JDBC connection
2013-04-03 11:47:40 DEBUG SQL:111 - select GMRPPLD4.PERSON_SEQ.nextval from dual
Hibernate: select GMRPPLD4.PERSON_SEQ.nextval from dual
2013-04-03 11:47:40 DEBUG SequenceGenerator:114 - Sequence identifier generated: BasicHolder[java.lang.Integer[21]]
2013-04-03 11:47:40 DEBUG AbstractBatcher:418 - about to close PreparedStatement (open PreparedStatements: 1, globally: 1)
2013-04-03 11:47:40 DEBUG ConnectionManager:427 - aggressively releasing JDBC connection
2013-04-03 11:47:40 DEBUG ConnectionManager:464 - releasing JDBC connection [ (open PreparedStatements: 0, globally: 0) (open ResultSets: 0, globally: 0)]
2013-04-03 11:47:40 DEBUG SequenceHiLoGenerator:85 - new hi value: BasicHolder[java.lang.Integer[21]]
2013-04-03 11:47:40 DEBUG AbstractSaveEventListener:135 - generated identifier: 1050, using strategy: org.hibernate.id.SequenceHiLoGenerator
Persons: id=[1050] birthDate=[java.util.GregorianCalendar[time=1365004060605,areFieldsSet=true,areAllFieldsSet=true,lenient=true,zone=sun.util.calendar.ZoneInfo[id="America/New_York",offset=-18000000,dstSavings=3600000,useDaylight=true,transitions=235,lastRule=java.util.SimpleTimeZone[id=America/New_York,offset=-18000000,dstSavings=3600000,useDaylight=true,startYear=0,startMode=3,startMonth=2,startDay=8,startDayOfWeek=1,startTime=7200000,startTimeMode=0,endMode=3,endMonth=10,endDay=1,endDayOfWeek=1,endTime=7200000,endTimeMode=0]],firstDayOfWeek=1,minimalDaysInFirstWeek=1,ERA=1,YEAR=2013,MONTH=3,WEEK_OF_YEAR=14,WEEK_OF_MONTH=1,DAY_OF_MONTH=3,DAY_OF_YEAR=93,DAY_OF_WEEK=4,DAY_OF_WEEK_IN_MONTH=1,AM_PM=0,HOUR=11,HOUR_OF_DAY=11,MINUTE=47,SECOND=40,MILLISECOND=605,ZONE_OFFSET=-18000000,DST_OFFSET=3600000]] 
2013-04-03 11:47:40 WARN  EntityManagerImpl:138 - Entity Manager closed by someone else (hibernate.transaction.auto_close_session must not be used)
2013-04-03 11:47:41 INFO  SessionFactoryImpl:935 - closing
2013-04-03 11:47:41 INFO  SessionFactoryImpl:935 - closing
4

2 に答える 2

1

私の場合、envers 3.5.1 から 3.5.6 にアップグレードすると問題が解決しました。

于 2014-07-17T13:42:38.897 に答える
0

つまり、いくつかのテストを実行しました:JTA + envers +

  1. hibernate 3.6.1 - コミットエラー
  2. hibernate 4 - コミットはエラーなしで終了しますが、データは保持されません
  3. jpa (休止状態 4) - すべて正常に動作します

JBoss をコンテナーとして使用し、Oracle (XA 構成) を DB として使用しました。

JTA を使用しない構成では、envers のバージョンに関係なく問題は発生しません

于 2013-06-26T07:47:53.980 に答える