gpt4 book ai didi

java - Hibernate加载策略

转载 作者:行者123 更新时间:2023-12-02 00:42:49 25 4
gpt4 key购买 nike

我们正在将 OpenSessionInView 与 Spring MVC 应用程序结合使用。我不知道如何最好地处理这种情况。主要是因为我对 Hibernate 不太熟悉。我们有 2 个对象,会为我们查看的每个页面加载。假设我们正在开发 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 来获取 session ,然后更新人员和站点 - 或者我们仍然会加载这些值?

显然,这些查询并不是那么重量级,但有时保存其他稍微重一些的东西会很有用,以便尝试从数据库中卸载工作。

最佳答案

如果您的目标是从数据库卸载工作,那么您应该考虑使用二级缓存。由于相同的人和站点经常被读取并且很少更新,因此这些实体的二级缓存非常适合,并且将有效地减少这些实体的加载次数,而无需更改代码中的任何内容。

参见http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/performance.html#performance-cache

关于java - Hibernate加载策略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5868833/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com