采用的是ehcache 缓存,需要引入ehcache.jar 支持包。主要就是优化数据库操作层的代码。
1、定义缓存工具类 EhcacheUtil.java:
package lsxy.report.tool;
import net.sf.ehcache.CacheException;
import net.sf.ehcache.CacheManager;
public class EhcacheUtil {
private EhcacheUtil() {
}
private static CacheManager cacheManager = null;
static {
try {
cacheManager = CacheManager.create();
} catch (CacheException e) {
e.printStackTrace();
}
}
public static CacheManager getCacheManager() {
return cacheManager;
}
}
2、数据库操作层类代码引入ehcache 后的优化:
public class ReportCodeDao {
private BasicDB db = new BasicDB();
/**
* 根据codeId获取对应的名称
*
* @param cid
* @return
* @throws CacheException
* @throws IllegalStateException
*/
public String getCodeDesc(String cid) throws Exception {
String codedesc = "";
// 获取CacheManager
CacheManager cacheManager = EhcacheUtil.getCacheManager();
// 用配置文件中配置的colorcache创建cache缓存
Cache cache = cacheManager.getCache("codeCache");
// 查看cache中是否存在cid的缓存
Element element = cache.get(cid);
// 如果不存在,从数据库中查询
if (element == null) {
String sql = "select codedesc from TBL_REPORT_CODEDESC where cid='"
+ cid + "'";
// System.out.println("从数据库中查询!" + sql);
ResultSet rs = db.executeQuery(sql);
try {
if (rs.next())
codedesc = rs.getString("codedesc");
} catch (SQLException e) {
e.printStackTrace();
} finally {
db.closed();
}
cache.put(new Element(cid, codedesc));
} else {// 如果存在,从缓存中加载
// System.out.println("从缓存中加载!");
codedesc = element.getValue().toString();
}
// System.out.println("codedesc:" + codedesc);
return codedesc;
}
3、缓存配置文件ehcache.xml
timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" />
timeToIdleSeconds="300" timeToLiveSeconds="600" overflowToDisk="true" />