Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/hibernate/5.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

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/multithreading/4.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
Hibernate 休眠会话模式默认设置为手动_Hibernate_Spring Mvc_Hibernate Session - Fatal编程技术网

Hibernate 休眠会话模式默认设置为手动

Hibernate 休眠会话模式默认设置为手动,hibernate,spring-mvc,hibernate-session,Hibernate,Spring Mvc,Hibernate Session,我有一个简单的SpringMVC-Hibernate应用程序,当连接到MySQL5.5数据库时,它可以很好地插入和读取数据。将同一应用程序连接到Oracle 10g时,它从数据库中读取记录,但无法插入记录 在调试时,我发现会话的刷新模式是手动的。保存记录后,我显式地编写了session.flush,代码开始在两个数据库中正常工作 我的问题- 正如我从Hibernate中了解到的,默认的刷新模式是自动。在我的代码中,我没有将它设置为手动,但不知怎么的,它已经设置好了。如何控制 我正在使用Sprin

我有一个简单的SpringMVC-Hibernate应用程序,当连接到MySQL5.5数据库时,它可以很好地插入和读取数据。将同一应用程序连接到Oracle 10g时,它从数据库中读取记录,但无法插入记录

在调试时,我发现会话的刷新模式是手动的。保存记录后,我显式地编写了session.flush,代码开始在两个数据库中正常工作

我的问题- 正如我从Hibernate中了解到的,默认的刷新模式是自动。在我的代码中,我没有将它设置为手动,但不知怎么的,它已经设置好了。如何控制

我正在使用Spring3.1.1和Hibernate3.5.6。下面是我的root-context.xml和servlet-context.xml文件

servlet-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/>
<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>
root-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/>
<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>
如果需要更多细节,请告诉我


谢谢。

检查您是否已打开OpenSessionInViewFilter筛选器。这似乎是罪魁祸首