1

MySQL 5.5データベースに接続すると、正常に機能する(データの挿入と読み取り)単純なSpring MVC - Hibernateアプリケーションがあります。同じアプリケーションを Oracle 10g に接続すると、データベースからレコードが読み取られましたが、レコードを挿入できませんでした。

デバッグ時に、セッションの flushMode が MANUAL であることがわかりました。レコードを保存した後に明示的に session.flush() を記述したところ、両方のデータベースでコードが正しく機能し始めました。

私の問題- Hibernateのドキュメントからわかるように、デフォルトのフラッシュ モードは AUTO です。コードで手動に設定していませんが、どういうわけか設定されています。これを制御する方法は?

Spring 3.1.1 と Hibernate 3.5.6 を使用しています。以下は私の root-context.xml と servlet-context.xml ファイルです。

サーブレット-context.xml:

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
    <property name="prefix" value="/WEB-INF/views/"/>
    <property name="suffix" value=".jsp"/>
</bean>

<context:component-scan base-package="com.home.cfs"/>

<mvc:annotation-driven/>

root-context.xml:

<bean id="databaseDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <!-- 
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
    <property name="url" value="jdbc:oracle:thin:@localhost:1521:testdb"/>
    <property name="username" value="test_usr"/>
    <property name="password" value="test_usr"/>
     -->

    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/person"/>
    <property name="username" value="root"/>
    <property name="password" value="admin"/> 

</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="databaseDataSource"/>
    <property name="packagesToScan" value="com.home.cfs"/>
    <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration"/>
    <property name="hibernateProperties">
        <props>
            <!-- <prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop> -->
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.format_sql">true</prop>
            <prop key="hibernate.use_sql_comments">true</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
        </props>
    </property>
</bean>

<tx:annotation-driven/>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory"/>
</bean>

詳細が必要な場合はお知らせください。

ありがとう。

4

1 に答える 1

0

OpenSessionInViewFilterフィルターをオンにしているかどうかを確認してください。これが原因である可能性が高いようです。

于 2013-03-06T13:14:41.690 に答える