Загруженные записи не обновлены. Использование Hibernate и OpenSessionInViewFilter - PullRequest
2 голосов
/ 29 ноября 2010

Я использую OpenSessionInViewFilter, Spring и Hibernate для доступа к данным. Когда я фиксирую запись данных, мои результаты просмотра не показывают зафиксированную запись с использованием отложенной загрузки. Моя заводская конфигурация сеанса выглядит так:

<bean id="dbcpDataSource" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" value="${database.driver}" />
    <property name="url" value="${database.url}" />
    <property name="username" value="${database.user}" />
    <property name="password" value="${database.password}" />
    <property name="poolPreparedStatements" value="true" />
    <property name="defaultAutoCommit" value="true" />
</bean>

<tx:annotation-driven transaction-manager="txManager" />
<bean id="txManager"
    class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dbcpDataSource" />
</bean>

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dbcpDataSource" />
    <property name="annotatedClasses">
        <list>
            <value>or.pac.Address</value>
            <value>or.pac.Customer</value>
            <value>or.pac.Documents</value>
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
            <prop key="hibernate.connection.release_mode">auto</prop>
            <prop key="hibernate.current_session_context_class">jta</prop>
            <prop key="hibernate.transaction.auto_close_session">true</prop>
            <prop key="hibernate.show_sql">false</prop>
            <prop key="hibernate.generate_statistics">false</prop>
            <prop key="hibernate.cache.use_query_cache">true</prop>
            <prop key="hibernate.max_fetch_depth">4</prop>
            <prop key="hibernate.cache.use_second_level_cache">true</prop>
            <prop key="hibernate.cache.use_query_cache">true</prop>
            <prop key="hibernate.cache.region.factory_class">net.sf.ehcache.hibernate.EhCacheRegionFactory</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
        </props>
    </property>
</bean> 
   <bean id="locator" class="cc.SessionLocator">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>

OpenSessionInViewFilter Конфигурация в web.xml выглядит именно так:

    <filter>
    <filter-name>openSessionInViewFilter</filter-name>
    <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
    <init-param>
        <param-name>singleSession</param-name>
        <param-value>true</param-value>
    </init-param>
    <init-param>
        <param-name>flushMode</param-name>
        <param-value>AUTO</param-value>
    </init-param>
    <init-param>
        <param-name>sessionFactoryBeanName</param-name>
        <param-value>sessionFactory</param-value>
    </init-param>
</filter>

<filter-mapping>
    <filter-name>openSessionInViewFilter</filter-name>
    <url-pattern>/*</url-pattern>
    <dispatcher>FORWARD</dispatcher>
</filter-mapping>

Чтобы получить сеанс для моего DAO у меня есть класс SessionLocator, который открывает сеанс для меня;

public class SessionLocator{

public static final ThreadLocal session = new ThreadLocal();
private static SessionLocator me;

static {
    try {
        me = new SessionLocator();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

private SessionLocator() throws HibernateException, JDBCException {
}

public static Session currentSession() throws Exception {
    Session s = (Session) session.get();
    if (s != null) {
        s.setCacheMode(CacheMode.REFRESH);
    }

    if (s == null) {
        synchronized SessionLocator{
            s =openSession();
        }
        session.set(s);
    }

    return s;
}



public void setSessionFactory(SessionFactory sessionFactory) {
    PersistenceManager.sessionFactory = sessionFactory;
}

public static Session openSession() {
    Session session = SessionFactoryUtils.doGetSession(sessionFactory, true);
    return session;
}

private static SessionFactory sessionFactory;

}

А затем в Мой сервис DAO Я сохраняю и обновляю так:

    public boolean upsert(Object d) {
    try {
        SessionLocator.currentSession().saveOrUpdate(d);
                } catch (Exception e) {
        e.printStackTrace();
        return false;
    }
    return true;
}

Когда я вызываю upsert(), я вижу запись в таблице, но обновленное значение не отображается в моем представлении во время отложенной загрузки. Кто-нибудь знает, почему кэш спящего режима не обновляется с текущей записью?

1 Ответ

1 голос
/ 01 декабря 2010

Эта проблема была решена путем удаления строки ниже из конфигурации openSessionInViewFilter:

<dispatcher>FORWARD</dispatcher>

И аннотировать службу DAO аннотацией @Transactional

@Transactional
public boolean upsert(Object d) {
try {
    SessionLocator.currentSession().saveOrUpdate(d);

    } catch (Exception e) {

    e.printStackTrace();
    return false;
   }
   return true;
   }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...