繁体   English   中英

如何避免多次执行相同的查询?

[英]How to avoid same query execution multiple times?

我需要一种可以避免多次执行相同查询的方法。 从代码的角度来看,我不需要任何帮助。 较高级别的方法会很好。

目前,我正在不同的类中执行相同的休眠查询,并且这些执行是同一请求的一部分。 到目前为止,我正在使用请求级缓存来存储数据。 稍后,我将从缓存而不是数据库中获取这些数据,以提高性能。 但是我想知道除上述方法之外,还有其他方法可以遵循。

如果您可以提供帮助,将非常有帮助。

谢谢

您可以注册一个将实现ServletContextListener的Web侦听器。 您将需要实现contextInitialized (应用程序部署)和contextDestroyed (应用程序取消部署)。

@WebListener
public final class CacheBootstrap implements ServletContextListener {

    @Override
    public void contextInitialized(ServletContextEvent sce) {
       // load data into cache (hql?)
    }

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
       // unload data from cache (hql?)
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM