Mercurial > dive4elements > gnv-client
view geo-backend/src/main/java/de/intevation/gnv/geobackend/base/query/CachingQueryExecutorFactory.java @ 661:f99d8f92a640
Implemented Support of MultiPolygons.
geo-backend/trunk@750 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Tim Englich <tim.englich@intevation.de> |
---|---|
date | Mon, 08 Mar 2010 15:39:58 +0000 |
parents | f0b6d0e2a0f6 |
children | 8b442223741c |
line wrap: on
line source
package de.intevation.gnv.geobackend.base.query; import java.util.Collection; import net.sf.ehcache.Cache; import net.sf.ehcache.Element; import net.sf.ehcache.CacheManager; import org.apache.log4j.Logger; import de.intevation.gnv.geobackend.base.Result; /** * @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: