我们在Spring MVC应用程序中使用OpenSessionInView。我不确定如何最好地处理这种情况。主要是因为我对Hibernate并不熟悉。我们有两个对象,我们查看每个页面。让我们假装我们正在开发CMS。因此,我们必须加载每个页面上登录的人员以及他们当前正在处理的站点。在正常的操作过程中,这些数据都没有真正改变。
我们有一个自定义拦截器,它基本上是这样的:
public class PersistenceInterceptor implements HandlerInterceptor {
private PlatformTransactionManager transactionManager; //from spring
private TransactionStatus transactionStatus;
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
this.transactionStatus = transactionManager.getTransaction(new DefaultTransactionDefinition());
if (handler instanceof SpecialInterface) {
handler.setPerson(loadPersonByKey(session.getAttribute(PERSON_KEY)));
handler.setSite(loadSiteByKey(session.getAttribute(SITE_KEY)));
}
return true;
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//Wrapped in try catch & rolled back if unable to commit
transactionManager.commit(transactionStatus);
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
if (ex != null && !transactionStatus.isCompleted()) {
transactionManager.rollback(transactionStatus);
}
}
我们是否最好修改我们的方式,并稍微修改一下以使用我们配置的Hibernate sessionFactory来获取会话,然后更新人员&网站 - 或者我们仍然会加载这些值?
显然,这些查询并不是那么重要,但有时候保存其他更重要的东西来尝试从数据库卸载工作会很有用。
答案 0 :(得分:3)
如果您的目标是从数据库卸载工作,那么您应该考虑使用二级缓存。由于相同的人员和站点经常被读取并且很少更新,因此这些实体的二级缓存非常适合,并且将有效地减少这些实体的加载次数,而无需更改代码中的任何内容。 / p>
请参阅http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/performance.html#performance-cache