1

私の Spring-3.0.5/Hibernate-3.3.0 webapp はコレクションを保存しません。関連付けられたコレクションを使用して新しい永続オブジェクトを作成すると、オブジェクトは永続化されますが、コレクションは永続化されません。テストケースではすべてがうまく機能するので、マッピングアノテーションに問題はありません。

ログレベル TRACE を使用してテスト ケースと webapp を実行すると、テスト ケースは ("[fF]lush" の grep:

AbstractFlushingEventListener - flushing session
AbstractFlushingEventListener - processing flush-time cascades
AbstractFlushingEventListener - dirty checking collections
AbstractFlushingEventListener - Flushing entities and processing referenced collections
AbstractFlushingEventListener - Processing unreferenced collections
AbstractFlushingEventListener - Scheduling collection removes/(re)creates/updates
AbstractFlushingEventListener - Flushed: 0 insertions, 0 updates, 0 deletions to 4 objects
AbstractFlushingEventListener - Flushed: 2 (re)creations, 0 updates, 0 removals to 3 collections

しかし、webapp は次のように言うだけです:

org.hibernate.impl.SessionImpl - setting flush mode to: MANUAL

「SessionImpl」を取得すると、

DEBUG: org.hibernate.impl.SessionImpl - opened session at timestamp: 13071848978
DEBUG: org.springframework.orm.hibernate3.HibernateTransactionManager - Opened new Session [org.hibernate.impl.SessionImpl@acaf083] for Hibernate transaction
DEBUG: org.springframework.orm.hibernate3.HibernateTransactionManager - Preparing JDBC Connection of Hibernate Session [org.hibernate.impl.SessionImpl@acaf083]
TRACE: org.hibernate.impl.SessionImpl - setting cache mode to: GET
TRACE: org.hibernate.impl.SessionImpl - setting cache mode to: NORMAL
TRACE: org.hibernate.impl.SessionImpl - setting cache mode to: GET
TRACE: org.hibernate.impl.SessionImpl - setting cache mode to: NORMAL
TRACE: org.hibernate.impl.SessionImpl - after transaction completion
TRACE: org.hibernate.impl.SessionImpl - closing session

テストケースと

DEBUG: org.hibernate.impl.SessionImpl - opened session at timestamp: 13071842364
TRACE: org.hibernate.impl.SessionImpl - setting flush mode to: MANUAL
TRACE: org.hibernate.impl.SessionImpl - closing session

ウェブアプリ用。

webapp が常に自動フラッシュを無効にする理由がわかりません!

これが私のWebapp-Configurationです(明確さの略):

  <tx:annotation-driven proxy-target-class="true"/>
  <context:spring-configured/>
  <context:component-scan base-package="de.halbekunst.fotos" />
  <mvc:annotation-driven />

そして私のリソース定義:

  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
    <property name="driverClass" value="${jdbc.driverClassName}"/>
    <property name="jdbcUrl">
      <value><![CDATA[${jdbc.url}]]></value>
    </property>
    <property name="user" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
    <property name="minPoolSize" value="3"/>
    <property name="maxPoolSize" value="30"/>
    <property name="acquireIncrement" value="3"/>
    <property name="maxIdleTime" value="25200"/>
    <property name="maxIdleTimeExcessConnections" value="14400"/>
    <property name="idleConnectionTestPeriod" value="7200"/>
    <property name="maxStatements" value="50"/>
    <property name="preferredTestQuery" value="SELECT 1;"/>
  </bean>

  <!-- Hibernate SessionFactory -->
  <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="packagesToScan" value="de.halbekunst.fotos"/>
    <property name="hibernateProperties">
      <value>
        hibernate.dialect=${hibernate.dialect}
        hibernate.query.substitutions=true 'Y', false 'N'
        hibernate.cache.use_second_level_cache=false
        hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider
      </value>
      <!-- Turn batching off for better error messages under PostgreSQL -->
      <!-- hibernate.jdbc.batch_size=0 -->
    </property>
  </bean>

  <!-- Transaction manager for a single Hibernate SessionFactory (alternative to JTA) -->
  <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory"/>
  </bean>
4

1 に答える 1

2

1 週間のデバッグの後 (記述されたエラーの原因を特定できるようになるまで、元のプロジェクトをストライプ化しました)、何が問題だったのかがわかりました。

障害のあるコントローラーの公開されたメソッドは公開されていなかったため、アノテーションは効果がありませんでした。

同様の問題を抱えている人のために:これは私のプロジェクトの縮小版で、エラーを示しています:

https://github.com/kai-moritz/experiment

Mavenが必要です!この例を実行するには、2 つのコマンドを実行するだけです

mvn war:inpace
mvn jetty:run
于 2011-06-13T16:33:56.710 に答える