Mercurial > dive4elements > gnv-client
view geo-backend/src/main/java/de/intevation/gnv/geobackend/base/query/CachingQueryExecutorFactory.java @ 886:8b442223741c
Ordered imports. Removed empty headers.
geo-backend/trunk@856 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Mon, 29 Mar 2010 09:22:07 +0000 |
parents | f0b6d0e2a0f6 |
children | b757def3ff55 |
line wrap: on
line source
package de.intevation.gnv.geobackend.base.query; import de.intevation.gnv.geobackend.base.Result; import java.util.Collection; import net.sf.ehcache.Cache; import net.sf.ehcache.CacheManager; import net.sf.ehcache.Element; import org.apache.log4j.Logger; /** * @author Sascha L. Teichmann <sascha.teichmann@intevation.de> */ public class CachingQueryExecutorFactory extends QueryExecutorFactory { public static final String QUERY_EXECUTOR_FACTORY = "caching.query.executor.config"; public static final String CACHE_NAME = "sql.cache"; private static Logger log = Logger.getLogger(CachingQueryExecutorFactory.class); protected CacheManager manager; public CachingQueryExecutorFactory() { log.info("using SQL cache"); String configFile = System.getProperty(QUERY_EXECUTOR_FACTORY); manager = configFile != null ? new CacheManager(configFile) : new CacheManager(); manager.addCache(CACHE_NAME); } public QueryExecutor getQueryExecutor() { return new DefaultQueryExceutor() { public Collection<Result> cachedResults(String query) { Cache cache = manager.getCache(CACHE_NAME); Element element = cache.get(query); if (log.isDebugEnabled()) { log.debug("found results in SQL cache: " + (element != null)); } return element != null ? (Collection<Result>)element.getObjectValue() : null; } public void cacheResults(String query, Collection<Result> results) { log.debug("store results in SQL cache"); Cache cache = manager.getCache(CACHE_NAME); cache.put(new Element(query, results)); } }; } public void shutdown() { log.info("shutting down SQL cache"); manager.getCache(CACHE_NAME).flush(); manager.shutdown(); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8: